ホームページ >データベース >mysql チュートリアル >準備されたステートメントでの PHP PDOException「無効なパラメーター番号」エラーを解決するにはどうすればよいですか?

準備されたステートメントでの PHP PDOException「無効なパラメーター番号」エラーを解決するにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-12-11 07:42:14882ブラウズ

How to Resolve the PHP PDOException

PHP PDOException: 「無効なパラメーター番号」エラーへの対処

このエラーは通常、クエリが間違った数のパラメーターをバインドしようとしたときに発生します。 PDO 準備済みステートメント。提供されたコードでは、エラーはクエリ文字列での名前付きプレースホルダーの使用が原因である可能性があります。

元のクエリ:

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

に対して同じ名前付きプレースホルダー ":hash" が使用されています。最初の挿入と更新の両方。ただし、PDO では、バインドされる値ごとに一意のパラメーター マーカーが必要です。

この問題を解決するには、update 句のプレースホルダーの名前を次のように変更します。

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

さらに、パラメーターの配列をバインドします。 execute() メソッド:

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

この変更により、バインドされる各値が一意のパラメーター マーカーを持つようになり、 「パラメータ番号が無効です」エラー。

以上が準備されたステートメントでの PHP PDOException「無効なパラメーター番号」エラーを解決するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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