ホームページ >バックエンド開発 >PHPチュートリアル >PDO プリペアド ステートメントで「無効なパラメータ番号」エラーがスローされるのはなぜですか?

PDO プリペアド ステートメントで「無効なパラメータ番号」エラーがスローされるのはなぜですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-12-15 02:46:16961ブラウズ

Why Does My PDO Prepared Statement Throw an

PDO 例外: 無効なパラメータ番号

add_persist 関数を実行しようとすると、「SQLSTATE[HY093]: 無効なパラメータ番号」エラーが発生しますに遭遇します。この関数は永続テーブルにデータを挿入し、重複キーが見つかった場合はハッシュ値を更新します。

コードを調べると、問題が SQL ステートメントにあることが明らかになります。このステートメントは、:hash パラメーターを 2 回バインドしようとします。1 回目は INSERT 操作で、もう 1 回は ON DUPLICATE KEY UPDATE 操作です。

このエラーを解決するには、SQL ステートメントを変更して、ステートメントの実行時に各値がステートメントに渡されます。変更されたステートメントと実行コードは次のとおりです。

$sql = "INSERT INTO persist (user_id, hash, expire) VALUES (:user_id, :hash, :expire) ON DUPLICATE KEY UPDATE hash=:hash2";
$stm->execute(array(":user_id" => $user_id, ":hash" => $hash, ":expire" => $future, ":hash2" => $hash));

PHP ドキュメントによると、準備されたステートメント内で同じ名前のパラメーター マーカーを 2 回使用することは無効です。このエラーを回避するには、各値に独自の一意のパラメーター マーカーが必要です。

以上がPDO プリペアド ステートメントで「無効なパラメータ番号」エラーがスローされるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。