ホームページ >データベース >mysql チュートリアル >SQL の WHERE と HAVING: データ フィルタリングに各句をいつ使用するか?

SQL の WHERE と HAVING: データ フィルタリングに各句をいつ使用するか?

DDD
DDDオリジナル
2025-01-14 17:21:43843ブラウズ

WHERE vs. HAVING in SQL: When to Use Each Clause for Data Filtering?

SQL における WHERE 句と HAVING 句の違いと使用法

SQL (構造化照会言語) は、データベース データを操作および取得するための強力なツールです。 COUNT() や SUM() などのデータ集計関数を使用する場合は、HAVING 句と WHERE 句の違いを理解することが重要です。

概要

WHERE 句は、集計前に行をフィルタリングするために使用されます。テーブル内の個々の行に対して条件を評価します。

HAVING 句は、集計後に行をフィルタリングするために使用されます。集計されたデータに基づいて条件を評価します。

主な違い

HAVING と WHERE の最も重要な違いは、フィルタリングのタイミングです。

  • WHERE: 集計前に行をフィルターします。
  • HAVING: 集計後に行をフィルターします。

次の例を考えてみましょう:

<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: は、最小数または最大数、平均、またはその他の集計データに基づいてグループを選択するなど、集計統計をフィルタリングするのに役立ちます。

WHERE と HAVING のタイミングの違いを理解することで、開発者は集計の前後に特定の条件に基づいてデータベースからデータを効率的に取得できます。

以上がSQL の WHERE と HAVING: データ フィルタリングに各句をいつ使用するか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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