首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用SQL表上的数据填充下拉列表?

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

Stack Overflow用户
提问于 2017-08-01 17:12:40
回答 1查看 49关注 0票数 0

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

代码语言:javascript
运行
复制
<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函数如下所示。

代码语言:javascript
运行
复制
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列。请帮帮我。谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-08-01 17:22:48

要使用mysqli_result::fetch_array()获得多个值,您需要将其放入一个while-循环中:

代码语言:javascript
运行
复制
function get_all(){
     $sql = "SELECT * FROM food_list";
     $ref = $this->db->query($sql);

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

     return $ar;
}

这将返回如下数组:

代码语言:javascript
运行
复制
Array (
     Array (
          [item_name] => Item 1 name
          [unit_price] => 15.00
     )
     Array (
          [item_name] => Item 2 name
          [unit_price] => 20.00
     )
)
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45443973

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档