dsfd3546 2012-04-13 18:38
浏览 39
已采纳

在PHP中的'mysql_fetch_row'中用'foreach'更改'while'

Is it possible to change while by foreach in mysql_fetch_row in PHP?

For example

$result = mysql_query("SELECT * FROM test");

while ($row = mysql_fetch_row($result)) {
    print_r($row);
}

This will take all records(rows) from query SELECT * FROM test.

But, if foreach is used

foreach (mysql_fetch_row($result) as $row) {
    print_r($row);
}

This will take only first record(row) from query SELECT * FROM test.

Is it possible get all records by foreach loop when using with mysql_fetch_row ?

  • 写回答

2条回答 默认 最新

  • dongzao9044 2012-04-13 18:40
    关注

    You can only use foreach if:

    • you create a class that implements ArrayAccess or Iterator, or
    • you obtain the whole result set in an array and use that array with foreach.

    You could use a for loop, but the code would be less than readable:

    for ($row = mysql_fetch_row($result); $row !== false; $row = mysql_fetch_row($result)) {
        print_r($row);
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 poi合并多个word成一个新word,原word中横版没了.
  • ¥15 【火车头采集器】搜狐娱乐这种列表页网址,怎么采集?
  • ¥15 求MCSCANX 帮助
  • ¥15 机器学习训练相关模型
  • ¥15 Todesk 远程写代码 anaconda jupyter python3
  • ¥15 我的R语言提示去除连锁不平衡时clump_data报错,图片以下所示,卡了好几天了,苦恼不知道如何解决,有人帮我看看怎么解决吗?
  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?