効率的なデータ取得: 複数の WHERE 条件を賢く組み合わせる
2 つの異なる条件セットに基づいてテーブルからデータを取得する必要があるとします。たとえば、財務業務を記録し、「account_id」、「budget_id」、「points」、「type」などの列を含む「transactions」というテーブルがあるとします。
このテーブルから特定のデータを効率的に取得するには、複数の WHERE 句を組み合わせる必要がある場合があります。たとえば、テーブル内の固有の「budget_id」ごとに割り当ておよび発行される合計ポイントを決定する必要がある場合があります。
クエリのアイデア
構築する必要があるクエリは次のようになります:
<code class="language-sql">SELECT budget_id, SUM(CASE WHEN type = 'allocation' THEN points ELSE 0 END) AS allocated, SUM(CASE WHEN type = 'issue' THEN points ELSE 0 END) AS issued FROM transactions GROUP BY budget_id</code>
このクエリの各コンポーネントを詳しく見て、目的を達成する方法を理解しましょう:
SUM(CASE WHEN ... THEN ... ELSE ... END) 関数:
この関数は、指定された「タイプ」に基づいて「ポイント」列を条件付きで合計するために使用されます。 「種類」が「割り当て」の場合、この条件を満たすすべての行の「ポイント」の合計を計算します。同様に、「タイプ」が「発行」と等しい行の「ポイント」の合計を計算します。 (ここでは、コードの可読性と互換性を向上させるために、IF
関数がより標準的な CASE WHEN
に置き換えられています)
budget_id ごとにグループ化:
この句は、取得したデータを「budget_id」列ごとにグループ化します。したがって、クエリはテーブル内の個別の「budget_id」ごとに個別の結果行を提供します。
WHERE 句の組み合わせ:
必要なフィルタリングが SUM() 関数内で行われるため、このクエリには WHERE 句が著しく欠落しています。具体的には、この関数には、「type」列に基づいて行を選択的に含める条件が含まれています。
期待される出力:
作成したクエリは、「budget_id」、「allocated」、および「issued」列を含むテーブルを出力します。 「割り当て」列は、各「budget_id」の「割り当て」トランザクションに関連付けられたポイントの合計を表し、「発行」列は、対応する「budget_id」の「発行」トランザクションの累積ポイントを表します。
以上が単一の SQL クエリで複数の WHERE 句のような条件を効率的に組み合わせるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。