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 $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 быть массивом значений.

ОБНОВИТЬ

Этот ответ устарел. Используйте оператор распространения в более новых версиях 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; } 

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

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

Dunno, почему слово «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.