ホームページ >バックエンド開発 >PHPチュートリアル >PDO で複数の ID を使用して「WHERE... IN」クエリを適切に実行するにはどうすればよいですか?

PDO で複数の ID を使用して「WHERE... IN」クエリを適切に実行するにはどうすればよいですか?

DDD
DDDオリジナル
2024-10-30 08:03:02370ブラウズ

How to Properly Execute

複数の ID を使用した "WHERE... IN" クエリの適切な PDO 構文

ID のリストに基づいてデータベース レコードを削除する場合、データの整合性を維持することは非常に重要です。 PDO で遭遇する一般的な課題の 1 つは、複数の値を指定して "WHERE... IN" クエリを実行することです。

あなたの場合、クエリはカンマ区切りのリストを単一の値。これを解決するには、リスト内の各 ID のプレースホルダーを含める必要があります。

解決策:

PDO プリペアド ステートメントで ID のリストを正しく使用するには、次のようにします。次の手順に従ってください:

  1. カンマ区切りの ID リストを配列に変換します (例: $idlist = ['260', '201', '221', ...];.
  2. 必要なプレースホルダーの数を表す疑問符の文字列を作成します (例: $questionmarks = str_repeat("?,", count($idlist)-1) 。 「?」;。これにより、10 個の ID に対して「?,,,,,,,,,」のような文字列が生成されます。
  3. 疑問符文字列を含む PDO ステートメントを準備します。例: $stmt = $dbh->prepare( "DELETE FROM foo WHERE id IN ($questionmarks)");.
  4. 最後に、ID 配列をループし、各値を対応するプレースホルダーにバインドします (例:

    <code class="php">foreach ($idlist as $id) {
     $stmt->bindParam(..., $id);
    }</code>
  5. これらの手順に従うことで、複数の ID を使用して "WHERE... IN" クエリを正確に実行し、データの一貫性を維持できます。

以上がPDO で複数の ID を使用して「WHERE... IN」クエリを適切に実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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