php – PDO bindParam在foreach中不起作用

我正在使用PDO作为应用程序但是PDO bindparam()遇到了问题.我有一个数组,我想使用for循环或foreach()的PDO bindparam()数组的值,但foreach()得到意想不到的结果.当我在for循环中使用bindparam()时,它运行正常.我试过的是

$con = $this->connection();
$stmt = $con->prepare($sql);

for($i = 0; $i < count($params); $i++){
   $stmt->bindParam($i + 1, $params[$i], PDO::ParaM_STR, 10);
}
$stmt->execute();
$result = $stmt->fetchAll();//$result is OK

但是当我在foreach()中使用bindparam()时,我得到一个空数组()作为结果.代码下方

$con = $this->connection();
$stmt = $con->prepare($sql);

foreach($params as $key=>$val){ //Here
    $stmt->bindParam($key + 1, $val, PDO::ParaM_STR, 10);
}
$stmt->execute();
$result = $stmt->fetchAll(); //$result is an empty array

我想知道为什么会这样.我找不出原因.任何信息将不胜感激.

编辑:我使用bindValue()解决了我的问题.

解决方法:

使用bindValue()而不是bindparam(). bindparam()绑定到引用,因此当您执行查询时,所有参数都使用$val的最后一个值.

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...