SQL中的GROUP BY用法

GROUP BY 是 SQL 中用来"按列分组"的子句

它把相同值的行分到同一个组 ,然后通常配合聚合函数COUNT, SUM, AVG, MAX, MIN 等)对每个组做统计,最终每组只返回一行结果。


✅ 1. 基本语法

sql 复制代码
SELECT 列1, 列2, 聚合函数(列3)
FROM 表名
GROUP BY 列1, 列2;
  • 规则SELECT 后面出现的非聚合列 ,必须全部出现在 GROUP BY 中。
    SELECT name, age, COUNT(*) FROM emp GROUP BY name;(错误,age 没分组)
    SELECT name, age, COUNT(*) FROM emp GROUP BY name, age;

✅ 2. 工作流程(3 步)

  1. 按 GROUP BY 列的值分组
  2. 把每组内的行聚合(用聚合函数)
  3. 每组返回一行结果

✅ 3. 示例表:sales

order_id region product amount
1 华北 苹果 100
2 华北 苹果 200
3 华南 苹果 150
4 华南 香蕉 80

🔍 按 region 分组,统计销售额

sql 复制代码
SELECT region,
       SUM(amount) AS total_sales
FROM sales
GROUP BY region;

结果:

复制代码
region | total_sales
-------|------------
华北   | 300
华南   | 230

🔍 按 region + product 分组,统计订单数

sql 复制代码
SELECT region,
       product,
       COUNT(*) AS order_cnt
FROM sales
GROUP BY region, product;

结果:

复制代码
region | product | order_cnt
-------|---------|----------
华北   | 苹果    | 2
华南   | 苹果    | 1
华南   | 香蕉    | 1

✅ 4. 常见搭配

搭配 作用 示例
GROUP BY + HAVING 对聚合结果再过滤 HAVING SUM(amount) > 200
GROUP BY + ORDER BY 对分组结果排序 ORDER BY total_sales DESC
GROUP BY + 多列 更细粒度分组 GROUP BY region, product

✅ 5. 易错点

  • SELECT 里写了列,却没写进 GROUP BY → 报错(MySQL 除外,它有宽松模式)。
  • WHEREHAVING 的区别:
    • WHERE:在分组前过滤原始行
    • HAVING:在分组后过滤聚合结果

✅ 6. 一句话总结

GROUP BY 就是"把相同值的行捆成一组,然后对每组做统计",是 SQL 里做报表、汇总、统计的核心工具。

相关推荐
逻辑驱动的ken44 分钟前
Java高频面试考点18
java·开发语言·数据库·算法·面试·职场和发展·哈希算法
qq_392690661 小时前
Redis怎样应对Redis集群整体宕机带来的雪崩
jvm·数据库·python
快乐非自愿2 小时前
Redis--SDS字符串与集合的底层实现原理
数据库·redis·缓存
这儿有一堆花2 小时前
住宅代理(Residential Proxy)技术指南
开发语言·数据库·php
茉莉玫瑰花茶2 小时前
LangChain 核心组件 [ 2 ]
java·数据库·langchain
存在的五月雨3 小时前
Mysql 索引的一些
数据库·mysql
黄俊懿3 小时前
MySQL主从复制:从“异步“到“GTID“,数据同步的进化之路
数据库·sql·mysql·oracle·架构·dba·db
看海的四叔4 小时前
【SQL】SQL-管好你的字符串
大数据·数据库·hive·sql·数据分析·字符串
秋94 小时前
TiDB 数据库全链路实战指南:从下载部署到 Java 高并发调优
java·数据库·tidb
zhou周大哥4 小时前
银河麒麟安装mysql
数据库·mysql