搜索
首页 > 数据库 > SQL > 正文

SQL 分组查询如何实现多级统计?

冷漠man
发布: 2025-09-22 22:31:01
原创
822人浏览过
使用ROLLUP、CUBE、GROUPING SETS或UNION可实现SQL多级统计:ROLLUP按层级生成小计和总计,如年月销售汇总;CUBE生成所有分组组合,适用于交叉分析;GROUPING SETS自定义分组级别,灵活指定汇总维度;UNION ALL合并多个独立分组查询,兼容性强且便于标注层级。不同方法适用于不同数据库与场景,结合GROUPING()函数可区分汇总行。

sql 分组查询如何实现多级统计?

在 SQL 中实现多级统计,通常是指对数据进行多层次的分组汇总,比如按地区、部门、年月逐层统计销售额。这类需求可以通过 GROUP BY 配合一些扩展语法来实现,常见的方法包括使用 ROLLUPCUBEGROUPING SETS,也可以通过子查询或 UNION 手动构造多级汇总。

1. 使用 GROUP BY ROLLUP 实现层级汇总

ROLLUP 可以生成从最细粒度到最高层级的累计汇总行,适合有明确层级关系的字段(如 年 → 月)。

示例:按年、月统计订单金额,并包含每月小计和年度总计

SELECT 
    year, 
    month, 
    SUM(amount) AS total_amount
FROM sales
GROUP BY ROLLUP (year, month);
登录后复制

结果会包含:

  • 每一年每一月的数据
  • 每一年的合计(month 为 NULL)
  • 所有年份的总合计(year 和 month 均为 NULL)

2. 使用 GROUP BY CUBE 生成所有组合

CUBE 会生成所有可能的分组组合,适用于需要交叉分析的场景。

示例:按产品类别和区域统计销量,包含所有组合(类总计、区总计、总合计等)

SELECT 
    category, 
    region, 
    SUM(sales) AS total_sales
FROM sales_data
GROUP BY CUBE (category, region);
登录后复制

输出包括:

蓝心千询
蓝心千询

蓝心千询是vivo推出的一个多功能AI智能助手

蓝心千询34
查看详情 蓝心千询
  • 每个 category + region 的明细
  • 每个 category 的汇总(region 为 NULL)
  • 每个 region 的汇总(category 为 NULL)
  • 整体总和(都为 NULL)

3. 使用 GROUPING SETS 自定义汇总级别

GROUPING SETS 允许你精确指定想要的分组方式,灵活性更高。

示例:只想看按年汇总、按月汇总和总体总和,不要年月组合的交叉项

SELECT 
    year, 
    month, 
    SUM(amount) AS total
FROM sales
GROUP BY GROUPING SETS ((year), (month), ());
登录后复制

这将返回:

  • 每年的总金额
  • 每月的总金额
  • 全部总额

4. 使用 UNION 联合多个分组查询

如果数据库不支持 ROLLUP 或 CUBE,或者你需要更复杂的逻辑控制,可以用 UNION ALL 拼接不同层级的查询。

示例:分别查出按部门、按岗位、以及公司总人数

SELECT 'dept' AS level, dept AS group_name, COUNT(*) AS cnt FROM employees GROUP BY dept
UNION ALL
SELECT 'job', job, COUNT(*) FROM employees GROUP BY job
UNION ALL
SELECT 'total', 'all', COUNT(*) FROM employees;
登录后复制

这种方式便于添加标签说明统计层级,也容易做格式化输出

基本上就这些。根据你的数据库类型(如 MySQL、PostgreSQL、SQL Server)和具体需求选择合适的方法。ROLLUP 和 CUBE 简洁高效,GROUPING SETS 更灵活,UNION 则兼容性强、控制精细。注意配合 GROUPING() 函数或判断 NULL 来区分汇总行和原始数据行,避免混淆。

以上就是SQL 分组查询如何实现多级统计?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 //m.sbmmt.com/ All Rights Reserved | php.cn | 湘ICP备2023035733号