26

无法弄清楚,是什么导致了 mysqli_stmt::bind_param() 的错误参数 3 应该是一个参考,在...中给出的值

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 引起了问题。

那么,$params 有什么问题呢?我需要 $params 是一个值数组。

4

3 回答 3

57

更新

这个答案已经过时了。请在较新的 PHP 版本中使用扩展运算符,如 Stacky 回答的。

来自 php 文档:

将 mysqli_stmt_bind_param() 与 call_user_func_array() 一起使用时必须小心。请注意,mysqli_stmt_bind_param() 需要通过引用传递参数,而 call_user_func_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;
}
于 2013-04-20T13:30:49.640 回答
34

在 PHP 5.6 中引入,您可以使用...运算符(“扩展运算符”)以更少的麻烦达到相同的结果:

//object-oriented
$sql_stmt->bind_param($param_type, ...$params);

//procedural
mysqli_stmt_bind_param($sql_stmt, $param_type, ...$params);
于 2017-10-13T07:34:40.873 回答
1

不知道为什么在代码中使用“PDO”一词,但这是其中唯一正确的词。使用PDO,并且使用 mysqli 准备好的语句不会遇到问题:

$query = "INSERT INTO test (id,row1,row2,row3) VALUES (?,?,?,?)";
$params = array(1,"2","3","4");
$stmt = $pdo->prepare($query);
$stmt->execute($params);

只需看看这个干净简洁的代码,并将其与您需要的带有 mysqli 准备好的语句的代码进行比较。

于 2013-04-20T13:25:41.883 回答