woo*_*ata 23 php arrays mysqli
无法弄清楚,是什么导致错误参数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);
Run Code Online (Sandbox Code Playgroud)
还尝试了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();
Run Code Online (Sandbox Code Playgroud)
但同样的错误,只是现在参数2导致问题.
那么,$ params有什么问题?我需要$ params作为一个值数组.
bit*_*ing 57
UPDATE
这个答案已经过时了.请使用更新的PHP版本中的spread运算符,如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;
}
Run Code Online (Sandbox Code Playgroud)
Sta*_*cky 27
在PHP 5.6中引入,您可以使用...
运算符("扩展运算符")以更少的麻烦实现相同的结果:
//object-oriented
$sql_stmt->bind_param($param_type, ...$params);
//procedural
mysqli_stmt_bind_param($sql_stmt, $param_type, ...$params);
Run Code Online (Sandbox Code Playgroud)