Mysqli bind_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
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 быть массивом значений.
Ответы
Ответ 1
UPDATE
Этот ответ устарел. Используйте оператор распространения в новых версиях PHP, например, ответил Stacky.
Из php document:
Следует соблюдать осторожность при использовании 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;
}
Ответ 2
В PHP 5.6 вы можете использовать ...
operator ( "оператор распространения" ) для достижения того же результата с меньшими проблемами
mysqli_stmt_bind_param($sql_stmt, $param_type, ...$params);
Ответ 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.