php中的嵌套循环的工作方式与expectd不同

php中的嵌套循环的工作方式与expectd不同,php,mysql,Php,Mysql,我试图在循环中检索MySQL数据。但只有第一个是显示数据。其他的是空的。这就是它现在的工作原理- 这是我的密码: <?php for ($i = 1; $i <= $quantity; $i++) { echo' <tr> <!-- <td><input class="case" type="checkbox"/></td> -->

我试图在循环中检索MySQL数据。但只有第一个是显示数据。其他的是空的。这就是它现在的工作原理-

这是我的密码:

<?php

for ($i = 1; $i <= $quantity; $i++) {
    echo'
        <tr>
            <!-- <td><input class="case" type="checkbox"/></td> -->                         
            <td><input type="text" data-type="productCode" name="itemNo[]" id="itemNo_1" class="form-control autocomplete_txt" autocomplete="off" placeholder="Enter IMEI number"></td>
            <td><select name="brand[]"  class="form-control autocomplete_txt">';
    while ($row = mysqli_fetch_array($result_brand)) {
        echo '<option value="' . $row['brand'] . '">' . $row['brand'] . '</option>';
    }
    echo'  </select> </td> <td><select name="model[]"  class="form-control autocomplete_txt" >';
    if (mysqli_num_rows($result_model) > 0) {
        // output data of each row
        while ($row_model = mysqli_fetch_assoc($result_model)) {
            echo ' <option value="' . $row_model['model'] . '">' . $row_model['model'] . '</option>';
        }
    }
    echo'   
        </select>                       
        </td>
        <td><input type="text" data-type="productName" name="brand[]" id="itemName_1" class="form-control autocomplete_txt" autocomplete="off" placeholder="Brand"></td> 
        <td><input type="text" data-type="productName" name="model[]" id="itemName_2" class="form-control autocomplete_txt" autocomplete="off" placeholder="Model"></td> 
        <td><input type="number" name="price[]" id="price_1" class="form-control changesNo" autocomplete="off" onkeypress="return IsNumeric(event);" ondrop="return false;" onpaste="return false;"></td>
        <td><input type="number" value="1" name="quantity[]" id="quantity_1" class="form-control changesNo" autocomplete="off" onkeypress="return IsNumeric(event);" ondrop="return false;" onpaste="return false;" disabled></td>
        <!-- <td><input type="number" name="total[]" id="total_1" class="form-control totalLinePrice" autocomplete="off" onkeypress="return IsNumeric(event);" ondrop="return false;" onpaste="return false;" disabled></td> -->                             
    </tr>
    ';
}
?>


我不确定到底是什么问题

问题在于
mysqli
结果的游标在
循环运行一次后指向结果的末尾

您必须在
for
循环开始时调用,以将游标重置为第一个数据集:

for($i=1; $i<=$quantity; $i++) {
    mysqli_data_seek($result_brand, 0);
    mysqli_data_seek($result_model, 0);
...

for($i=1;$i请向我们显示品牌和model@Kuya:刚刚添加了查询。您是否检查了mysqli_num_rows($result_model)
的输出?是否确实大于0?@minitauros:它有24行。@mario.klumo:您是我的英雄