为什么php调用存储过程返回多个结果集,总要多出一个结果集

php中文网
发布: 2016-06-23 14:12:30
原创
959人浏览过

比如
$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的值!!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号