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中文网其他相关文章!