dousa1630 2015-06-19 02:21
浏览 6
已采纳

以下是bind_param PHP的方法有什么区别

I'm just getting over using the singleton approach and am starting to get into prepared statements... I'm racking my brain on why one version of this works and one does not when, to me, they seem to be the same thing... I really want it to work the second way in order to meet my end goal.

This works:

call_user_func_array(array($stmt, 'bind_param'), array("i", 2));

This does not:

$params = array("i", 2);
call_user_func_array(array($stmt, 'bind_param'), $params);
  • 写回答

1条回答 默认 最新

  • doulaozhang0238 2015-06-19 03:13
    关注

    You are probably getting an error message like

    mysqli_stmt::bind_param() expected to be a reference, value given in...

    The problem is that bind_param() in PHP 5.3+ requires array values as reference while 5.2 works with real values.

    From the docs:

    Care must be taken when using mysqli_stmt_bind_param() in conjunction with call_user_func_array(). Note that mysqli_stmt_bind_param() requires parameters to be passed by reference, whereas call_user_func_array() can accept as a parameter a list of variables that can represent references or values (ref).


    One solution is to create an array of references

    $params = array("i", 2);
    $tmp = array();
    foreach($params as $key => $value) {
        $tmp[$key] = &$params[$key];
    }
    call_user_func_array(array($stmt, 'bind_param'), $tmp); 
    

    and another similar solution is

    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; 
    } 
    
    $params = array("i", 2);
    call_user_func_array(array($stmt, 'bind_param'), refValues($params));
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 要这个数学建模编程的代码 并且能完整允许出来结果 完整的过程和数据的结果
  • ¥15 html5+css和javascript有人可以帮吗?图片要怎么插入代码里面啊
  • ¥30 Unity接入微信SDK 无法开启摄像头
  • ¥20 有偿 写代码 要用特定的软件anaconda 里的jvpyter 用python3写
  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算
  • ¥15 powerbuilder中的datawindow数据整合到新的DataWindow