PHP

mysqli bind_param()应该是一个引用,给定值

发布于 2021-02-02 12:02:46

无法弄清楚,是什么导致错误 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是值数组。

关注者
0
被浏览
60
1 个回答
  • 面试哥
    面试哥 2021-02-02
    为面试而生,有面试问题,就找面试哥。

    更新

    这个答案已经过时了。请在较新的PHP版本(如Stacky回答)中使用传播运算符。

    从php docu:

    将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;
    }
    


知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看