为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

收到一只叮咚 2019-11-04 09:25:46
无法弄清楚,是什么导致错误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);也尝试过OOPOOP$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是值数组。
查看完整描述

3 回答

?
侃侃尔雅

TA贡献1801条经验 获得超16个赞

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

}


查看完整回答
反对 回复 2019-11-04
?
FFIVE

TA贡献1797条经验 获得超6个赞

在PHP 5.6中引入的,您可以使用...运算符(“扩展运算符”)以较少的麻烦来实现相同的结果:


//object-oriented

$sql_stmt->bind_param($param_type, ...$params);


//procedural

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


查看完整回答
反对 回复 2019-11-04
?
哈士奇WWW

TA贡献1799条经验 获得超6个赞

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准备好的语句与所需的代码进行比较即可。


查看完整回答
反对 回复 2019-11-04
  • 3 回答
  • 0 关注
  • 582 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信