mysql_fetch_row查询结果不完整,为什么是隔行显示结果?

使用mysql_fetch_row函数查询数据库结果,显示的只是数据库内隔行的结果,而不是完整的结果,请问什么原因呢?代码如下:

while(mysql_fetch_row($result)){
    echo '<pre>';
    print_r(mysql_fetch_row($result));
    echo '</pre>';
}

这段代码只能显示部分的结果,如图:查询结果

数据库截图:数据库中全部内容

2,使用以下代码可以查询全部结果,为什么?

while($arr = mysql_fetch_row($result)){
    echo '<pre>';
    print_r($arr);
    echo '</pre>';
}
阅读 3k
2 个回答

应该是mysql_fetch_row($result)每执行一次会把指针往后移一条
第一次在while后面的括号里执行了一次,没有输出
然后代码块里执行了一次并输出
然后又循环一次 执行没有输出
然后代码块里执行一次并输出
然后while里条件为假,停止

新手上路,请多包涵

每次 fetch 完相当于把指针向下移了一位,第一种写法每次都向下移两位(while 里面一次,print_r里面一次),所以就每隔一个输出了。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题