当前位置: 首页 > 面试题库 >

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

东郭宏深
2023-03-14
问题内容

无法弄清楚,是什么导致错误 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是值数组。


问题答案:

更新

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


 类似资料:
  • 考虑一个例子: 在这个简单的例子中,clang(输出:)和gcc(输出:)不一致。

  • 我有一个大程序,我几乎在每个类中都使用我的主类。我通常通过getInstance方法访问,但是每次我需要的时候我都会这样做。例如: 现在我想知道这是否非常有效,如果我为它声明一个变量并访问该变量是否更好: 如果我只在一种方法中需要它,如果我只在方法本身中声明它,它会更有效和更节省内存吗?提前谢谢!

  • 本文向大家介绍如果我截断一个表,是否还应该添加索引?,包括了如果我截断一个表,是否还应该添加索引?的使用技巧和注意事项,需要的朋友参考一下 如果截断表,则不需要添加索引,因为截断表后会重新创建表,并且会自动添加索引。 让我们首先创建一个表- 以下是创建索引的查询- 使用插入命令在表中插入一些记录- 截断表格之前,您需要检查表格状态- 输出结果 这将产生以下输出- 现在截断表- 现在再次检查表状态。

  • 将我的Spring Boot应用程序部署到Google App Engine时,我在尝试访问Web应用程序时收到404错误。该应用程序在本地运行良好,但拒绝在应用程序引擎上运行。我使用命令部署应用程序。 以下是部署应用程序后的日志: pom.xml: 应用程序.属性: application-mysql.properties: 主要: WebSecurityConfig: app.yaml: 编辑

  • 问题内容: 我有一些副作用要应用,并且想知道如何组织它们: 一次性使用 或几个useEffects 在性能和体系结构上有什么更好的选择? 问题答案: 您需要遵循的模式取决于您的useCase。 首先 ,您可能遇到以下情况:在初始安装期间需要添加事件侦听器,并在卸载时对其进行清理,而在另一种情况下,则需要清理特定的侦听器并在prop更改时将其重新添加。在这种情况下,使用两个不同的useEffect更

  • 我尝试用以下方法调用三个引用游标参数: 但是listOfObjects只包含cursor1的内容,无法获得cursor2的内容。