ホームページ >バックエンド開発 >PHPチュートリアル >PDO プリペアド ステートメントで「無効なパラメータ番号」エラーがスローされるのはなぜですか?
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 サイトの他の関連記事を参照してください。