我在应用程序中使用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但是,当我在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我想知道为什么会这样。我找不出原因。如有任何资料,将不胜感激。
编辑:我用bindValue()解决了我的问题。
发布于 2014-10-02 15:22:44
使用bindValue()而不是bindParam()。bindParam()绑定到引用,因此在执行查询时,所有参数都使用$val的最后一个值。
发布于 2014-10-02 15:22:18
如果数组中已有项,则没有理由在循环中调用$stmt->bindParam;只需:
$con = $this->connection();
$stmt = $con->prepare($sql);
$stmt->execute($params);
$result = $stmt->fetchAll();根据PHP文档
执行准备好的语句。如果准备好的语句包含参数标记,则必须: 调用PDOStatement::bindParam()将PHP变量绑定到参数标记:绑定变量将其值作为输入传递,并接收相关参数标记的输出值(如果有的话) 或者传递一个只输入的参数值数组。
https://stackoverflow.com/questions/26164076
复制相似问题