首页 >数据库 >mysql教程 >为什么我的 PHP PDO 准备语句抛出'无效参数号”?

为什么我的 PHP PDO 准备语句抛出'无效参数号”?

Linda Hamilton
Linda Hamilton原创
2024-12-08 07:22:11359浏览

Why Does My PHP PDO Prepared Statement Throw

PDO 异常:PHP 中的参数编号无效

尝试使用 PHP 时遇到错误“SQLSTATE[HY093]:无效的参数编号” PDO?根本原因可能与准备语句中的参数使用有关。

问题描述:

在提供的代码片段中:

$sql = "INSERT INTO persist (user_id, hash, expire) VALUES (:user_id, :hash, :expire) ON DUPLICATE KEY UPDATE hash=:hash";

有UPDATE 子句中缺少“:hash2”参数标记。这种差异会导致 PDO 异常,因为 PDO 需要为语句中绑定的每个值提供唯一的参数标记。

解决方案:

将准备好的语句的 SQL 查询调整为以下内容:

$sql = "INSERT INTO persist (user_id, hash, expire) VALUES (:user_id, :hash, :expire) ON DUPLICATE KEY UPDATE hash=:hash2";

相应地,修改execute()语句以包含":hash2" 参数标记:

$stm->execute(
    array(
        ":user_id" => $user_id,
        ":hash" => $hash,
        ":expire" => $future,
        ":hash2" => $hash
    )
);

背景:

PDO 的prepare() 方法在调用execute() 时需要唯一的参数标记来绑定值。不允许使用重复的参数标记,并且在“IN()”子句等子句中不支持为同一参数分配多个值。

以上是为什么我的 PHP PDO 准备语句抛出'无效参数号”?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn