ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
GROUP BY 句とは
GROUP BY 句は SQL で行をグループにまとめるための句です。指定した列の値が同じ行を 1 グループとし、集計関数と組み合わせてグループごとの集計値を取得します。
「部署ごとの平均給与」「日付ごとの売上合計」「商品カテゴリ別の在庫数」など、分析・レポートの基本道具です。
基本構文
SELECT
グループ化する列,
集計関数(対象列)
FROM テーブル
WHERE 条件 -- 集計前フィルタ
GROUP BY グループ化する列
HAVING 条件 -- 集計後フィルタ
ORDER BY 並び順;
サンプルデータ
| id | name | dept | salary |
|---|---|---|---|
| 1 | Alice | 営業 | 400 |
| 2 | Bob | 開発 | 500 |
| 3 | Carol | 営業 | 450 |
| 4 | Dave | 開発 | 600 |
| 5 | Eve | 人事 | 380 |
1. 単一列でグループ化
SELECT dept, COUNT(*) AS cnt, AVG(salary) AS avg_sal
FROM employees
GROUP BY dept;
| dept | cnt | avg_sal |
|---|---|---|
| 営業 | 2 | 425 |
| 開発 | 2 | 550 |
| 人事 | 1 | 380 |
2. 複数列でグループ化
SELECT dept, gender, COUNT(*) AS cnt
FROM employees
GROUP BY dept, gender;
dept と gender の組み合わせで 1 グループ。「営業×女性」「営業×男性」「開発×女性」… のようにまとめられます。
3. 主な集計関数
| 関数 | 意味 |
|---|---|
COUNT(*) | 行数 |
COUNT(列) | NULL 以外の行数 |
COUNT(DISTINCT 列) | 重複除外した値の数 |
SUM(列) | 合計 |
AVG(列) | 平均 |
MAX(列) | 最大 |
MIN(列) | 最小 |
STDDEV(列) / VARIANCE(列) | 標準偏差 / 分散 |
GROUP_CONCAT(列) (MySQL) | グループ内の値をカンマ連結 |
STRING_AGG(列, ',') (PostgreSQL / SQL Server) | 同上の標準形 |
4. WHERE と HAVING の違い
| 句 | 適用タイミング | 集計関数使用 |
|---|---|---|
WHERE | グループ化前に行をフィルタ | 不可 |
HAVING | グループ化後に結果をフィルタ | 可 |
-- 営業部だけ集計し、平均給与が 400 以上のグループのみ表示
SELECT dept, AVG(salary) AS avg_sal
FROM employees
WHERE join_year >= 2020 -- 集計前: 2020 年以降入社のみ
GROUP BY dept
HAVING AVG(salary) >= 400 -- 集計後: 平均 400 以上
ORDER BY avg_sal DESC;
5. SELECT に書ける列のルール
標準 SQL では、SELECT 句に書ける列は次のいずれかでなければエラー。
- GROUP BY 句に書いた列
- 集計関数の結果
- 定数
-- NG: name は GROUP BY にも集計関数にもない
SELECT dept, name, COUNT(*) FROM employees GROUP BY dept;
-- OK
SELECT dept, COUNT(*) FROM employees GROUP BY dept;
-- OK: name も GROUP BY に入れた
SELECT dept, name, COUNT(*) FROM employees GROUP BY dept, name;
MySQL は古いバージョンで緩く動いてしまうが、ONLY_FULL_GROUP_BY モード(5.7+ 既定)で標準的にエラーになる。
6. ROLLUP / CUBE / GROUPING SETS
標準 SQL の集計拡張。小計・総計を自動的に付与してくれる。
-- ROLLUP: 階層的に集計 (部署別 + 全社合計)
SELECT dept, SUM(salary)
FROM employees
GROUP BY ROLLUP(dept);
-- 結果:
-- 営業 850
-- 開発 1100
-- 人事 380
-- (全体) 2330 ← ROLLUP の追加行 (dept は NULL)
-- CUBE: 全ての組み合わせを集計
SELECT dept, gender, SUM(salary)
FROM employees
GROUP BY CUBE(dept, gender);
-- dept×gender, dept のみ, gender のみ, 全体 の全集計
-- GROUPING SETS: 指定した組み合わせだけ
SELECT dept, gender, SUM(salary)
FROM employees
GROUP BY GROUPING SETS ((dept), (gender), ());
7. NULL の扱い
GROUP BY では NULL も 1 グループとして扱われます(NULL = NULL とみなされる特例)。
SELECT category, COUNT(*)
FROM products
GROUP BY category;
-- category が NULL の商品も 1 グループとして集計される
8. 実行順序(SQL 句の評価順)
| 順 | 句 | 役割 |
|---|---|---|
| 1 | FROM / JOIN | 対象テーブルの結合 |
| 2 | WHERE | 行のフィルタ |
| 3 | GROUP BY | グループ化 |
| 4 | HAVING | グループのフィルタ |
| 5 | SELECT | 列の選択・計算 |
| 6 | ORDER BY | 並び替え |
| 7 | LIMIT / OFFSET | 件数制限 |
この順序を覚えると、SELECT のエイリアスが WHERE で使えないなどの仕様が腑に落ちます。
FAQ
Q: GROUP BY なしで集計関数だけ書いたら?
A: テーブル全体が 1 グループとして扱われ、1 行返る。SELECT COUNT(*) FROM employees; で全社員数。
Q: DISTINCT との違い
A: DISTINCT は重複を除くだけで集計不可。GROUP BY は集計可能。値の一覧だけ欲しいなら DISTINCT のほうが意図が明確。
Q: 集計関数を WHERE に書きたい
A: 不可。HAVING を使う。またはサブクエリで集計後の結果に WHERE。
Q: パフォーマンス
A: GROUP BY 対象列にインデックスがあると高速。複数列の場合は複合インデックスが効果的。EXPLAIN で確認。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- GROUP BY 句
- HAVING句
- ORDER BY 句
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?