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 里做报表、汇总、统计的核心工具。

相关推荐
IvorySQL14 小时前
双星闪耀温哥华:IvorySQL 社区两项议题入选 PGConf.dev 2026
数据库·postgresql·开源
ma_king17 小时前
入门 java 和 数据库
java·数据库·后端
jiayou6421 小时前
KingbaseES 实战:审计追踪配置与运维实践
数据库
NineData1 天前
NineData 迁移评估功能正式上线
数据库·dba
NineData2 天前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
阿里云大数据AI技术2 天前
用 SQL 调大模型?Hologres + 百炼,让数据开发直接“对话”AI
sql·llm
赵渝强老师2 天前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石2 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_3 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou644 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库