PDO bindParam在foreach中不起作用

MH2*_*2K9 4 php mysql pdo

我正在使用PDO一个应用程序,但遇到了问题PDO bindParam().我有一个数组,我想使用数组的值来PDO bindParam()使用for循环,foreach()但是意外的结果是通过foreach().当我bindParam()for循环中使用时,它工作正常.我试过的是

$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
Run Code Online (Sandbox Code Playgroud)

但是当我使用的时候bindParam(),foreach()我得到了一个空array()的结果.代码下方

$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
Run Code Online (Sandbox Code Playgroud)

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

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

Bar*_*mar 12

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


TML*_*TML 5

如果你已经有一个数组中的项目,没有理由$stmt->bindParam在循环中调用; 做就是了:

$con = $this->connection();
$stmt = $con->prepare($sql);
$stmt->execute($params);
$result = $stmt->fetchAll();
Run Code Online (Sandbox Code Playgroud)

根据PHP文档:

执行准备好的声明.如果准备好的语句包含参数标记,则必须:

调用PDOStatement :: bindParam()将PHP变量绑定到参数标记:绑定变量将其值作为输入传递,并接收其相关参数标记的输出值(如果有)

或传递一组仅输入参数值