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

PHP PDO コードで「SQLSTATE[HY093]: 無効なパラメータ番号」エラーがスローされるのはなぜですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-30 06:51:10888ブラウズ

Why Does My PHP PDO Code Throw a

PDOException: "SQLSTATE[HY093]: Invalidparameternumber" in PHP

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

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