【SQL】GROUP BY句でレコードをグループ化!使い方をサンプルコードで解説

  • 2024.12.12
       
【SQL】GROUP BY句の使い方をサンプルコードで解説

「GROUP BY」句とは?

SQLの「GROUP BY」句とは、任意のカラムの値に基づいてレコードをグループ化するのに用いられるクエリです。集計関数(SUMやCOUNTなど)と併用することで「クラスごとの人数を調べる」というように、グループごとの合計値やレコード数を求めることができます。また、「WHERE」句や「HAVING」句を併用して条件付きのグループ化を行ったり、「ORDER BY」句との併用でグループ化したグループの順番を並び変えるといった応用的な使い方もあります。特に、膨大なデータ量を扱う場合によく用いられるのでぜひ覚えておきたいクエリです。

「GROUP BY」句の基本構文

【使用イメージ】

SELECT 表示させるカラム名 FROM テーブル名 GROUP BY グループ化するカラム名;

あなたのご希望に沿った案件が必ず見つかります
【フリーランス向け】高収入好待遇の案件をご紹介

TECH MANIA フリーランス

≫まずは簡単60秒で無料お問い合わせから≪

【サンプルテーブル】

「GROUP BY」句の具体的な使い方を解説していくにあたって、サンプルとして「テスト」テーブルを用意しました。

「テスト」テーブル

id氏名性別点数
1001秋山80
1002久保田100
1003佐々木65
1004佐藤75
1005鈴木60
1006田中90
1007土屋55

集計関数「COUNT」でグループごとのレコード数を取得する

集計関数とは

集計関数とは、その項目の合計値や平均値を求めたり、あるいはCOUNT関数のようにデータ件数を取得するなど、その名の通り集計を行う関数のことです。これらを利用することで都度計算する必要がなくなり、データ分析などに使うと便利です。後ほど詳しく紹介しますが、集計関数とそれぞれ用途を以下に示しました。

集計関数用途
COUNT項目のデータ件数を取得する
SUM項目のデータ合計値を取得する
AVG項目のデータ平均値を取得する
MAX項目のデータ最大値を取得する
MIN項目のデータ最小値を取得する

データ件数を取得する「COUNT」関数を併用し、以下の実行コードでテストを受けた生徒の男女別の人数を求めます。

【実行コード】

SELECT 性別, COUNT(性別) FROM テスト GROUP BY 性別;

【実行結果】

性別COUNT(性別)
3
4

「性別」でグループ化を行い、性別とその数を抽出しています。

このように、「GROUP BY」句と「COUNT」関数を併用すればグループごとのレコード数を集計できます。

ほかにも、「SUM」関数を併用すればグループごとの合計値、「AVG」関数を併用すればグループごとの平均値が求められるので、ほかの関数を試してみるのもいいですね!

「GROUP BY」句を使う上での注意点

列名の指定を統一する

SELECT 表示させるカラム名 FROM テーブル名 GROUP BY グループ化するカラム名;

上記のように、対象の「カラム名」と「グループ化を行うカラム名」が同じ列(カラム)である必要があります。GROUP BY句で指定カラムを「集約キー」や「グループ化列」といいます。

× SELECT 氏名 FROM テスト GROUP BY 性別;

NULLも1つのグループとして扱われる

指定したカラムに「NULL」値が含まれている場合、「NULL値グループ」といったように、NULLも1つのグループとして集計されます。

条件を付けてグループごとのレコード数を取得する

「WHERE」句と「HAVING」句の違い

条件を付けるクエリに「WHERE」句と「HAVING」句がありますが、「GROUP BY」句と併用する場合、両者には以下の違いがあることを知っておく必要があります。

「WHERE」句:「GROUP BY」句の実行前に条件が適応される

「HAVING」句:「GROUP BY」句の実行後に条件が適応される

グループ化の前に任意の条件を満たさないレコードを省く場合は「WHERE」句を使い、グループ化後に任意の条件を満たさないグループを省く場合に「HAVING」句を使います。

「GROUP BY」句と「WHERE」句を併用してグループ化前に絞る

先ほどの「テスト」テーブルを用いて、生徒のうち、テストの点数が60点未満の生徒を除いた男女別の人数を表示させましょう。

「テスト」テーブル

id氏名性別点数
1001秋山80
1002久保田100
1003佐々木65
1004佐藤75
1005鈴木60
1006田中90
1007土屋55

【実行コード】

SELECT 性別, COUNT(性別) AS 人数 FROM テスト WHERE 点数>=60 GROUP BY 性別;

【実行結果】

性別人数
3
3

60点未満の土屋さんが除かれたことで、60点以上の生徒は男子が3名、女子が3名となりました。

「GROUP BY」句と「HAVING」句を併用してグループ化後に絞る

続いて、「テスト」テーブルのうち、人数が3人以下のグループのみ表示させましょう。

【実行コード】

SELECT 性別, COUNT(性別) AS 人数 FROM テスト GROUP BY 性別 HAVING 4>人数;

【実行結果】

性別人数
3

4人以上のグループが除かれたことで、男子生徒のみが表示されました。

「ORDER BY」句でグループ化したグループを並び替える

「ORDER BY」句とは

ORDER BY」句とは、任意のカラム(列)に基づいて結果をソート(並び替え)するクエリです。これにより、データの整理や分析を行いやすくなります。

例として、性別ごとにグループ化したグループを降順で並び替えます。

【実行コード】

SELECT 性別, COUNT(性別) AS 人数 FROM テスト GROUP BY 性別 ORDER BY 人数 DESK;

【実行結果】

性別COUNT(性別)
4
3

「ORDER BY」句を併用することで人数の多いチームから少ないチームに並び替えることができました。ちなみに、昇順(値が小さいものから大きいものへ)の場合は「ASK」を使用します。

【オマケ】GROUP BYとPARTITION BYの使い分け

GROUP BYと似た機能を持つ命令にPARTITION BYというものがあります。この2つはどちらも基準となる条件によってテーブルを分ける働きがありますが、大きな違いがあります。

集計関数とウィンドウ関数

GROUP BYは集計関数を使用する際にデータをまとめて集計する目的で使います。グループごとに1行に結果を集約したものが必要な場合に適しています。

一方で、PARTITION BYはウィンドウ関数を適用する際にデータを分割するために使用します。行ごとの計算や分析を行うケースに適しています。

実行結果の行数

GROUP BYはグループ化を行ったあと1行に集約した結果を返すのに対し、PARTITION BYは元の行数を維持しつつ、各行にウィンドウ関数を適用した結果を表示します。

SQLはクエリの組み立て方によって処理の重さなどが大きく変わります。より最適な処理を行い、最小のコストでクエリが実行できるように、使い分けていきましょう。

SQL関連記事

SQLの勉強方法は?

書籍やインターネットで学習する方法があります。昨今では、YouTubeなどの動画サイトやエンジニアのコミュニティサイトなども充実していて多くの情報が手に入ります。
そして、より効率的に知識・スキルを習得するには、知識をつけながら実際に手を動かしてみるなど、インプットとアウトプットを繰り返していくことが重要です。特に独学の場合は、有識者に質問ができたりフィードバックをもらえるような環境があると、理解度が深まるでしょう。

ただ、SQLに限らず、ITスキルを身につける際、どうしても課題にぶつかってしまうことはありますよね。特に独学だと、わからない部分をプロに質問できる機会を確保しにくく、モチベーションが続きにくいという側面があります。独学でモチベーションを維持する自信がない人にはプログラミングスクールという手もあります。費用は掛かりますが、その分スキルを身につけやすいです。しっかりと知識・スキルを習得して実践に活かしたいという人はプログラミングスクールがおすすめです。

プログラミングスクールならテックマニアがおすすめ!

ITスキル需要の高まりとともにプログラミングスクールも増えました。しかし、どのスクールに通うべきか迷ってしまう人もいるでしょう。そんな方にはテックマニアをおすすめします!これまで多くのITエンジニアを育成・輩出してきたテックマニアでもプログラミングスクールを開講しています。

<テックマニアの特徴>
・たしかな育成実績と親身な教育 ~セカンドキャリアを全力支援~
・講師が現役エンジニア ~“本当”の開発ノウハウを直に学べる~
・専属講師が学習を徹底サポート ~「わからない」を徹底解決~
・実務ベースでスキルを習得 ~実践的な凝縮カリキュラム~

このような特徴を持つテックマニアはITエンジニアのスタートラインとして最適です。
話を聞きたい・詳しく知りたいという方はこちらからお気軽にお問い合わせください。

     

Otherカテゴリの最新記事