为什么php调用存储过程返回多个结果集,总要多出一个结果集
$db->query("SET NAMES UTF8");
if($db->real_query("call sp_test()")){
do{
echo 'bp';
if($result = $db->store_result()){
while ($row = $result->fetch_assoc()){
array_push($rows, $row);
}
$result->close();
}
}while($db->next_result());
}
$db->close();
你会发现假设你返回1个结果集,会打出2个bp,2个结果集就会echo出3个bp,但如果不写存储,直接写语句,就正常,不会多出一个,求大神指点迷津!
回复讨论(解决方案)
这不是很正常吗?不然你要 if($result = $db->store_result()){ 干什么?
这不是很正常吗?不然你要 if($result = $db->store_result()){ 干什么?
您好,可是直接写语句在php里不会多出一个,比如select 1;select 2;
他就打出2个bp,这是为什么呢,存储过程里也写以上2句就会打出3个
php 的数据库函数不支持形如 select 1;select 2; 这样的查询,所以不能作为参照系
do{ if($result = $db->store_result()){ } }while($db->next_result());这样的代码结构是读取存储过程结果集必须的,如果你认为是 bug,可以去 php bug 网站去投诉。
不过在没有改正之前,你还是必须这么做
php 的数据库函数不支持形如 select 1;select 2; 这样的查询,所以不能作为参照系
do{ if($result = $db->store_result()){ } }while($db->next_result());这样的代码结构是读取存储过程结果集必须的,如果你认为是 bug,可以去 php bug 网站去投诉。
不过在没有改正之前,你还是必须这么做
非常感谢
因为你echo写在了 if($result = $db->store_result()){ 的前面,而有没有结果是要看 if($result = $db->store_result()){ 的判断结果才知道,所以肯定有2个结果的时候, if要判断3次,也就是你说的3次bp
其实简单说,你的困惑在于
$i = 1;$max = 2;while(true) { echo "A"; // 这里肯定会输出3个A if($i > $max) { break; } $i++; }
php 的数据库函数不支持形如 select 1;select 2; 这样的查询,所以不能作为参照系
do{ if($result = $db->store_result()){ } }while($db->next_result());这样的代码结构是读取存储过程结果集必须的,如果你认为是 bug,可以去 php bug 网站去投诉。
不过在没有改正之前,你还是必须这么做
大侠,不好意思,我还想问下,$result = $db->store_result(),这句话到底是什么意思,这是赋值运算,怎么就能返回bool值呢?
$db->store_result() 返回一个查询结果资源
当没有了的时候,返回的就是空了(null)
$db->store_result() 返回一个查询结果资源
当没有了的时候,返回的就是空了(null)
那$result =null 这个返回的是false吗?
还真是false,一个赋值表达式都能返回false,php真神奇
是我理解错了,运来if里面判断的仅仅是$result的值!!
上一篇: Lambda表达式学习
下一篇: linux下IPTABLES配置详解
推荐阅读
-
EF中调用存储过程,通过临时表返回一个结果集,不能返回的问题
-
php调用存储过程返回结果集
-
为什么php调用存储过程返回多个结果集,总要多出一个结果集
-
php调用存储过程返回结果集,解决cant return a result set in the given conte
-
为什么php调用存储过程返回多个结果集,总要多出一个结果集
-
php调用存储过程返回结果集,解决cant return a result set in_PHP教程
-
php调用存储过程返回结果集,解决cant return a result set in the given conte_PHP教程
-
为啥php调用存储过程返回多个结果集,总要多出一个结果集
-
请教一个调用带参数的MSSQL存储过程,返回结果集的问题
-
php调用存储过程返回结果集,解决cant return a result set in the given context错误的方法