3 回答
TA贡献1820条经验 获得超9个赞
MySQL客户端不允许您执行新查询,其中仍有从正在进行的查询中提取的行。有关常见错误,请参阅MySQL文档中的命令不同步。
您可以使用mysqli_store_result()
从外部查询中预取所有行。这将在MySQL客户端中缓冲它们,因此从服务器的角度来看,您的应用程序已获取完整的结果集。然后,即使在从now-buffered外部结果集中获取行的循环中,您也可以执行更多查询。
或者您mysqli_result::fetch_all()
将完整的结果集作为PHP数组返回,然后您可以循环该数组。
调用存储过程是一种特殊情况,因为存储过程有可能返回多个结果集,每个结果集可能有自己的一组行。这就是为什么@ a1ex07的回答提到使用mysqli_multi_query()
和循环直到mysqli_next_result()
没有更多的结果集。这是满足MySQL协议所必需的,即使在您的情况下您的存储过程只有一个结果集。
PS:顺便说一句,我看到你正在进行嵌套查询,因为你有代表层次结构的数据。您可能需要考虑以不同方式存储数据,以便您可以更轻松地查询它。我做了一个关于这个标题为SQL和PHP的分层数据模型的演示文稿。我还在我的SQL反模式:避免数据库编程陷阱的一章中讨论了这个主题。
以下是如何mysqli_next_result()
在CodeIgnitor 3.0.3中实现:
在system/database/drivers/mysqli/mysqli_driver.php
变化的第262行
protected function _execute($sql){ return $this->conn_id->query($this->_prep_query($sql));}
对此
protected function _execute($sql){ $results = $this->conn_id->query($this->_prep_query($sql)); @mysqli_next_result($this->conn_id); // Fix 'command out of sync' error return $results;}
这是自2.x以来的一个问题。我刚刚更新到3.x并且不得不将这个hack复制到新版本。
TA贡献2012条经验 获得超12个赞
简单地说,在调用mysqli_free_result之后,你必须调用mysqli_next_result($ db)。
mysqli_free_result($结果); mysqli_next_result($ db) mysqli_close($ db);
TA贡献1828条经验 获得超3个赞
只需调用此函数:
$this->free_result();function free_result() { while (mysqli_more_results($this->conn) && mysqli_next_result($this->conn)) { $dummyResult = mysqli_use_result($this->conn); if ($dummyResult instanceof mysqli_result) { mysqli_free_result($this->conn); } } }
添加回答
举报