脚本宝典收集整理的这篇文章主要介绍了php – 预处理语句中的递归,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
代码的基本逻辑是这样的.
function someFunction($something) { global $pdo; $array = array(); static $handle = null; if (!$handle) { $handle = $pdo->PRepare("A STATEMENT WITH :a_param"); } $handle->bindValue(":a_param",$something); if ($handle->execute()) { while ($row = $handle->fetch()) { $array[] = someFunction($row['blah']); } } return $array; }
它看起来很好,但它错过了很多行.最后我意识到语句句柄正在被改变(用不同的param执行),这意味着在while循环中调用fetch只会工作一次,然后函数再次调用自己,结果集也会改变.
所以我想知道以递归方式使用PDO预处理语句的最佳方法是什么.
一种方法可能是使用fetchAll(),但它在手册中说有很大的开销.这一点的全部意义在于提高效率.
我可以做的另一件事是不重用静态句柄,而是每次都创建一个新句柄.我相信,由于查询字符串是相同的,因此MysqL驱动程序内部无论如何都将使用预准备语句,因此在每次递归调用上创建新句柄的开销很小.就我个人而言,我认为这就失败了.
实际上,PDO会在您发出新准备时自动执行.
>初始句柄被分配(1)
>第一条记录是(1)
>该函数以递归方式调用. (1)的值驻留在递归堆栈中.
>新句柄被分配(2),无效(1)
>第一条记录是(2)
>函数返回
>您尝试获取(1)的下一条记录并失败,因为它无效
以上是脚本宝典为你收集整理的php – 预处理语句中的递归全部内容,希望文章能够帮你解决php – 预处理语句中的递归所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。