猿问

mysqli bind_param()应该是一个引用,给定值

无法弄清楚,是什么导致错误mysqli_stmt :: bind_param()的参数3有望作为参考,给出的值...


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是值数组。


收到一只叮咚
浏览 583回答 3
3回答

侃侃尔雅

这个答案已经过时了。请在较新的PHP版本(如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;}

FFIVE

在PHP 5.6中引入的,您可以使用...运算符(“扩展运算符”)以较少的麻烦来实现相同的结果://object-oriented$sql_stmt->bind_param($param_type, ...$params);//proceduralmysqli_stmt_bind_param($sql_stmt, $param_type, ...$params);

哈士奇WWW

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准备好的语句与所需的代码进行比较即可。
随时随地看视频慕课网APP
我要回答