首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >mysqli bind_param()应为引用,给定值

mysqli bind_param()应为引用,给定值
EN

Stack Overflow用户
提问于 2013-04-20 21:17:37
回答 3查看 20.4K关注 0票数 26

找不到导致错误的原因,mysqli_stmt::bind_param()的参数3应为引用,...中给出的值

代码语言:javascript
复制
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

代码语言:javascript
复制
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是一个值的数组。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-04-20 21:30:50

更新

这个答案已经过时了。请在更新的PHP版本中使用扩展运算符,如Stacky所回答的。

来自php docu:

在将mysqli_stmt_bind_param()与call_user_func_array()一起使用时,必须注意

。请注意,mysqli_stmt_bind_param()要求通过引用传递参数,而call_user_func_array()可以接受一系列变量作为参数,这些变量可以表示引用或值。

mysqli-stmt.bind-param页面上,你有不同的解决方案:

例如:

代码语言:javascript
复制
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;
}
票数 57
EN

Stack Overflow用户

发布于 2017-10-13 15:34:41

在PHP5.6中引入的,您可以使用... operator (“扩展运算符”)来实现相同的结果,并且麻烦更少:

代码语言:javascript
复制
//object-oriented
$sql_stmt->bind_param($param_type, ...$params);

//procedural
mysqli_stmt_bind_param($sql_stmt, $param_type, ...$params);
票数 34
EN

Stack Overflow用户

发布于 2013-04-20 21:25:42

不知道为什么代码中有“PDO”这个词,但这是唯一正确的词。使用PDO,不用面对mysqli prepared语句的问题:

代码语言:javascript
复制
$query = "INSERT INTO test (id,row1,row2,row3) VALUES (?,?,?,?)";
$params = array(1,"2","3","4");
$stmt = $pdo->prepare($query);
$stmt->execute($params);

只需查看这段干净简洁的代码,并将其与使用mysqli prepared语句所需的代码进行比较。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16120822

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档