SQL クエリ スキル: 同じ列に複数の条件を含むレコードを効率的にフィルタリングします
SQL データベースでは、特定の条件に基づいてレコードを取得するのは簡単そうに見えますが、同じ列に複数の条件が含まれている場合、要件を満たすレコードを効率的に選択することが課題になります。
例: ID、contactid、および flag の 3 つの列を含むテーブルがあるとします。次のクエリは、「Volunteer」タグと「Uploaded」タグの両方に関連付けられた contactid 値を返すように設計されています:
<code class="language-sql">SELECT contactid WHERE flag = 'Volunteer' AND flag = 'Uploaded'...</code>
ただし、このクエリは空の結果セットを返します。その理由は、クエリの論理解釈にあります。クエリは、フラグが「Volunteer」と「Uploaded」の両方に等しいレコードを検索しようとしますが、各レコードは 1 つのフラグ値しか持てないため、これは不可能です。
この問題を解決するには、2 つの実現可能な解決策があります:
オプション 1: GROUP BY と HAVING を使用する
このメソッドは、結果を contactid でグループ化し、HAVING 句を使用して一致するタグの数を指定することに依存しています。たとえば、「Volunteer」タグと「Uploaded」タグを一致させるには、次のクエリを使用します:
<code class="language-sql">SELECT contact_id FROM your_table WHERE flag IN ('Volunteer', 'Uploaded', ...) GROUP BY contact_id HAVING COUNT(*) = 2 -- // 必须与 WHERE flag IN (...) 列表中的数量匹配</code>
オプション 2: JOIN を使用する
ここでは、JOIN を利用して、共通の値に基づいてレコード間の関係を確立します。次のクエリを考えてみましょう:
<code class="language-sql">SELECT T1.contact_id FROM your_table T1 JOIN your_table T2 ON T1.contact_id = T2.contact_id AND T2.flag = 'Uploaded' -- // 如果需要,可以添加更多 JOIN WHERE T1.flag = 'Volunteer'</code>
このクエリはテーブル自体を contactid 列で結合し、複数のリンクを作成します。 WHERE 句により、最初の contactid が最初のフラグ条件 (「Volunteer」) を満たしていることが保証され、T2 への接続により、同じ contactid が 2 番目のフラグ条件 (「Uploaded」) も満たしていることが確認されます。
どのオプションが選択されるかは、タグ リストのサイズと予想される一致の頻度によって異なります。タグが多く、一致するものがほとんどない場合は、GROUP BY および HAVING を使用したクエリの方が効率的である可能性があります。タグ リストが小さく、一致が頻繁に発生する場合は、JOIN ベースのメソッドのパフォーマンスが向上する傾向があります。
以上がSQL で同じ列に複数の Where 条件があるレコードを効率的に選択するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。