PHP の PDO の使用中にエラー「SQLSTATE[HY093]: Invalidparameternumber」が発生した場合、これは通常、SQL ステートメントのパラメーター バインディングに問題があることを示します。この特定のケースでは、準備された SQL ステートメント内の名前付きプレースホルダーの数が、execute() メソッドに渡される値の数と一致しません。
提供されたコードが、一意の列とともに永続テーブルに挿入されます。 user_id、ハッシュ、有効期限を確認し、指定された user_id を持つ行がすでに存在する場合はハッシュ列を更新します。ただし、SQL ステートメントには、:hash の重複した名前付きパラメータ マーカーが含まれています。
このエラーを解決するには、ON DUPLICATE KEY UPDATE 句に別の名前付きパラメータを使用できます。修正されたコードは次のとおりです。
$sql = "INSERT INTO persist (user_id, hash, expire) VALUES (:user_id, :hash, :expire) ON DUPLICATE KEY UPDATE hash=:hash2"; $stm = $db->prepare($sql); $stm->execute( array( ":user_id" => $user_id, ":hash" => $hash, ":expire" => $future, ":hash2" => $hash, ) );
この修正されたバージョンでは、:hash2 パラメータを使用してバインドの問題を解決し、SQL ステートメントに正しい数のプレースホルダと値が含まれるようにします。
以上がPHP PDO コードで「SQLSTATE[HY093]: 無効なパラメータ番号」エラーがスローされるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。