加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 预处理语句中的递归

发布时间:2020-12-13 13:18:44 所属栏目:PHP教程 来源:网络整理
导读:我一直在使用PDO并准备我的所有陈述主要是出于安全原因.但是,我的代码中有一部分使用不同的参数执行相同的语句多次,我认为这将是准备好的语句真正发挥作用的地方.但他们实际上打破了代码…… 代码的基本逻辑是这样的. function someFunction($something) { g
我一直在使用PDO并准备我的所有陈述主要是出于安全原因.但是,我的代码中有一部分使用不同的参数执行相同的语句多次,我认为这将是准备好的语句真正发挥作用的地方.但他们实际上打破了代码……

代码的基本逻辑是这样的.

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)的下一条记录并失败,因为它无效

如上所述,MySQL不支持递归,这意味着你必须使用fetchAll在PHP端进行.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读