为什么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());
不过在没有改正之前,你还是必须这么做
php 的数据库函数不支持形如 select 1;select 2; 这样的查询,所以不能作为参照系
do{ if($result = $db->store_result()){ } }while($db->next_result());
不过在没有改正之前,你还是必须这么做
非常感谢
因为你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());
不过在没有改正之前,你还是必须这么做
大侠,不好意思,我还想问下,$result = $db->store_result(),这句话到底是什么意思,这是赋值运算,怎么就能返回bool值呢?
$db->store_result() 返回一个查询结果资源
当没有了的时候,返回的就是空了(null)
$db->store_result() 返回一个查询结果资源
当没有了的时候,返回的就是空了(null)
那$result =null 这个返回的是false吗?
还真是false,一个赋值表达式都能返回false,php真神奇
是我理解错了,运来if里面判断的仅仅是$result的值!!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

如何在系統重啟後自動設置unixsocket的權限每次系統重啟後,我們都需要執行以下命令來修改unixsocket的權限:sudo...

文章討論了PHP 5.3中介紹的PHP中的晚期靜態結合(LSB),允許靜態方法的運行時間分辨率調用以更靈活的繼承。 LSB的實用應用和潛在的觸摸

使用PHP的cURL庫發送JSON數據在PHP開發中,經常需要與外部API進行交互,其中一種常見的方式是使用cURL庫發送POST�...
