使用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>';
}
巴扎黑2017-04-11 10:36:07
应该是mysql_fetch_row($result)每执行一次会把指针往后移一条
第一次在while后面的括号里执行了一次,没有输出
然后代码块里执行了一次并输出
然后又循环一次 执行没有输出
然后代码块里执行一次并输出
然后while里条件为假,停止
巴扎黑2017-04-11 10:36:07
每次 fetch 完相当于把指针向下移了一位,第一种写法每次都向下移两位(while 里面一次,print_r里面一次),所以就每隔一个输出了。