使用SQL表上的数据填充下拉列表?

时间:2017-08-01 17:12:40

标签: php mysql

在我的php应用程序中,我有一个下拉列表,必须使用food_list表(项目名称)中的数据填充。 所以我有这些代码块。

<div class="col-sm-8">
 <select name="item_name" class="form-control">
    <option> -- select food item --</option>
     <?php
        $ba = $b->get_all();
        foreach($ba as $item){

            echo "<option>$item->item_name</option>";
        }

    ?>
   </select>

在我的课堂上,我的get_all函数如下所示。

function get_all(){
    $sql = "SELECT * FROM food_list";
    $ref = $this->db->query($sql);
    while($row=$ref->fetch_array()){
        $b=new foodlist();
        $b->item_name=$row['item_name'];
        $b->unit_price=$row['unit_price'];


        $ar[]=$b;
    }
    return $ar;
}

没有使用相关数据填充下拉列表的原因是什么。 注意:数据库连接正常运行

food_list(foodID,f_name,f_price)

数据应来自food_list表f_name列。 请善待我的帮助。 谢谢

1 个答案:

答案 0 :(得分:2)

要使用mysqli_result::fetch_array()获取多个值,您需要将其置于while循环中:

function get_all(){
     $sql = "SELECT * FROM food_list";
     $ref = $this->db->query($sql);

     while ($row = $ref->fetch_array()) {
          $ar[] = $row;
     }

     return $ar;
}

这将返回如下数组:

Array (
     Array (
          [item_name] => Item 1 name
          [unit_price] => 15.00
     )
     Array (
          [item_name] => Item 2 name
          [unit_price] => 20.00
     )
)
相关问题