SQL における WHERE 句と HAVING 句の違いと使用法
SQL (構造化照会言語) は、データベース データを操作および取得するための強力なツールです。 COUNT() や SUM() などのデータ集計関数を使用する場合は、HAVING 句と WHERE 句の違いを理解することが重要です。
概要
WHERE 句は、集計前に行をフィルタリングするために使用されます。テーブル内の個々の行に対して条件を評価します。
HAVING 句は、集計後に行をフィルタリングするために使用されます。集計されたデータに基づいて条件を評価します。
主な違い
HAVING と WHERE の最も重要な違いは、フィルタリングのタイミングです。
例
次の例を考えてみましょう:
<code class="language-sql">SELECT City, COUNT(*) AS AddressCount FROM Address WHERE State = 'MA' GROUP BY City</code>
このクエリは、WHERE 句を使用して、グループ化する前に州「MA」にあるすべてのアドレスを選択します。次に、結果を都市ごとにグループ化し、各都市の住所の数をカウントします。
次に、HAVING 句を使用してクエリを変更しましょう。
<code class="language-sql">SELECT City, COUNT(*) AS AddressCount FROM Address WHERE State = 'MA' GROUP BY City HAVING AddressCount > 5</code>
この変更されたクエリでは、集計後の結果をフィルタリングするために HAVING 句が使用されています。住所が 5 つ以上ある都市のみが選択されます。
WHERE と HAVING を使用する場合
WHERE と HAVING のタイミングの違いを理解することで、開発者は集計の前後に特定の条件に基づいてデータベースからデータを効率的に取得できます。
以上がSQL の WHERE と HAVING: データ フィルタリングに各句をいつ使用するか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。