SQLを使用してデータセットから情報を取得する際に、特定の条件を満たすアイテムの組み合わせだけを抽出したい場面があります。そのような複雑なクエリを効率的に実行するために、HAVING句を使用する方法について解説します。
目次
はじめに
SQLでは、GROUP BY句と組み合わせて使用されるHAVING句は非常に便利なツールです。HAVING句は、GROUP BY句でグループ化された後のデータに対して条件を指定し、その条件を満たす結果セットだけを抽出します。この記事では、具体的なSQLクエリを用いて、その使用方法を説明します。
基本的な構文
HAVING句の基本的な構文は以下のとおりです。
SELECT column1, column2, ...
FROM table
GROUP BY column1, column2, ...
HAVING condition;
HAVING句の使用例
環境の設定
まず、解説に使用するデータベーステーブルを設定します。ここでは、商品名、カテゴリ、価格が登録された仮想的なテーブルを作成します。
CREATE TABLE 商品 (
商品ID INT PRIMARY KEY,
商品名 VARCHAR(255),
カテゴリ VARCHAR(255),
価格 INT
);
INSERT INTO 商品 (商品ID, 商品名, カテゴリ, 価格)
VALUES (1, 'りんご', 'フルーツ', 300),
(2, 'バナナ', 'フルーツ', 200),
(3, 'おにぎり', '食品', 150),
(4, '水', '飲み物', 100),
(5, 'コーヒー', '飲み物', 250);
クエリ例
例えば、各カテゴリに属する商品の平均価格が200円以上のカテゴリを抽出したい場合、以下のようなSQLクエリが考えられます。
SELECT カテゴリ, AVG(価格) as 平均価格
FROM 商品
GROUP BY カテゴリ
HAVING AVG(価格) >= 200;
カテゴリ | 平均価格 |
---|---|
フルーツ | 250 |
飲み物 | 175 |
まとめ
HAVING句を使うことで、GROUP BY句によってグループ化された後のデータに対して特定の条件を適用し、その条件を満たす結果セットだけを効率よく抽出することが可能です。特にデータ分析などで複数の属性を持つアイテムの組み合わせを調査する際に、このHAVING句の使用は非常に有用です。
created by Rinker
¥4,554
(2025/01/19 14:23:45時点 Amazon調べ-詳細)
コメント