mysqli связывает param(), как ожидается, будет ссылкой, значение задано


Не могу понять, что вызывает ошибку Параметр 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
$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 был массивом значений.

Author: woopata, 2013-04-20

3 answers

ОБНОВЛЕНИЕ

Этот ответ устарел. Пожалуйста, используйте оператор распространения в более новых версиях 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;
}
 50
Author: bitWorking, 2017-11-16 14:23:31

Введенный в PHP 5.6, вы можете использовать ... оператор ("оператор распространения") для достижения того же результата с меньшими трудностями:

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

//procedural
mysqli_stmt_bind_param($sql_stmt, $param_type, ...$params);
 18
Author: Stacky, 2018-05-11 07:59:50

Не знаю, почему в коде слово "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.

 1
Author: Your Common Sense, 2017-05-23 10:31:37