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 サイトの他の関連記事を参照してください。