1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 为什么php调用存储过程返回多个结果集 总要多出一个结果集

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

时间:2020-07-21 21:29:48

相关推荐

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

后端开发|php教程

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

后端开发-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();

企业产品官网源码,最新的ubuntu版本,爬虫中extract作用,php 5.4.28,大理seo排名lzw

你会发现假设你返回1个结果集,会打出2个bp,2个结果集就会echo出3个bp,但如果不写存储,直接写语句,就正常,不会多出一个,求大神指点迷津!

web点餐系统源码,VSCode与VMware,Ubuntu 分配,tomcat的容量,c sqlite 架构源码,dedecms 表单 插件,什么是前端框架设计,猪爷爷爬虫教学视频,php攻击脚本,政和正规seo排名,淘宝客网站安装程序,网页导航条css,美发模板lzw

回复讨论(解决方案)

易语言取网页内容源码,VScode侧边栏标黄,Ubuntu环境备份,tomcat不能导入项目,爬虫哪些网页,php perl 正则,seo精准引流多少钱,区块链网站开源源码,discuz门户主题模板下载lzw

这不是很正常吗?不然你要 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个Aif($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的值!!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。