mysqli的bind_param()预期为基准,给定值(mysqli bind_param() e

2019-08-31 15:45发布

想不通,什么导致错误参数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会引起问题。

那么,什么是错$ PARAMS? 我需要$ PARAMS是值的数组。

Answer 1:

UPDATE

这个答案已经过时。 请使用蔓延运营商在新的PHP版本一样回答Stacky。

从PHP实况:

必须小心以call_user_func_array结合使用mysqli_stmt_bind_param()时,应考虑()。 需要注意的是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;
}


Answer 2:

在PHP 5.6推出,您可以使用...运算符 (“传播经营者”),以实现用更少的麻烦相同的结果:

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

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


Answer 3:

说不上为什么字“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预处理语句进行比较。



文章来源: mysqli bind_param() expected to be a reference, value given