mysqli bind_param()预期为引用

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (49)

不知道是什么导致了错误参数3到mysqli_stmt::BIND_Param()预期是一个参考,价值在...

PDO
$query = "INSERT INTO test (id,row1,row2,row3) VALUES (?,?,?,?)";
$params = array(1,"2","3","4");
$param_type = "isss";
$sql_stmt = mysqli_prepare ($mysqli, $query);
call_user_func_array('mysqli_stmt_bind_param', array_merge(array($sql_stmt, $param_type), $params));
mysqli_stmt_execute($sql_stmt);

也尝试过OOP

OOP
$insert_stmt = $mysqli->prepare($query);
array_unshift($params, $param_type);
call_user_func_array(array($insert_stmt, 'bind_param'), $params);
$insert_stmt->execute();

但是同样的错误,只是现在参数2引起了问题。

提问于
用户回答回答于

来自php docu:

使用mysqli时必须小心。_斯特姆特_绑定_Param()与Call_用户_漏斗_数组()。请注意,mysqli_斯特姆特_绑定_Param()要求通过引用传递参数,而调用_用户_漏斗_Array()可以接受可以表示引用或值的变量列表作为参数。

在页面上mysqli-stmt.bind-param你有不同的解决方案:

例如:

call_user_func_array(array($stmt, 'bind_param'), refValues($params));

function refValues($arr){
    if (strnatcmp(phpversion(),'5.3') >= 0) //Reference is required for PHP 5.3+
    {
        $refs = array();
        foreach($arr as $key => $value)
            $refs[$key] = &$arr[$key];
        return $refs;
    }
    return $arr;
}
用户回答回答于

在PHP 5.6中引入,可以使用操作者(“推广操作员”)为了获得同样的结果而不费那么大的麻烦:

mysqli_stmt_bind_param($sql_stmt, $param_type, ...$params);

扫码关注云+社区