SQL 中 ROLLUP 的使用方法

ROLLUP 是 SQL 中一种分组操作,它生成多个分组集的小计行和总计行,提供层次化的汇总数据。


基本语法

sql 复制代码
SELECT column1, column2, ..., aggregate_function(column)
FROM table
GROUP BY ROLLUP (column1, column2, ...);

使用示例

假设有一个销售表 sales

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

这个查询会生成:

  1. 每个地区每种产品的销售总额(最细粒度)

  2. 每个地区所有产品的销售小计

  3. 所有地区所有产品的销售总计


多列 ROLLUP

sql 复制代码
SELECT 
    year, 
    quarter, 
    month, 
    SUM(revenue) AS total_revenue
FROM financial_data
GROUP BY ROLLUP (year, quarter, month);

这会生成:

  1. 每年每季度每月的收入

  2. 每年每季度的收入小计

  3. 每年的收入小计

  4. 总收入总计

部分 ROLLUP

sql 复制代码
SELECT 
    department, 
    job_title, 
    gender, 
    AVG(salary) AS avg_salary
FROM employees
GROUP BY department, ROLLUP (job_title, gender);

结合其他 GROUP BY 功能

sql 复制代码
SELECT 
    store_id, 
    product_category, 
    product_subcategory,
    SUM(sales) AS total_sales
FROM retail_data
GROUP BY GROUPING SETS (
    (store_id, product_category, product_subcategory),
    ROLLUP (store_id, product_category)
);

识别汇总行

sql 复制代码
SELECT 
    CASE WHEN GROUPING(region) = 1 THEN 'All Regions' ELSE region END AS region,
    CASE WHEN GROUPING(product) = 1 THEN 'All Products' ELSE product END AS product,
    SUM(amount) AS total_sales
FROM sales
GROUP BY ROLLUP (region, product);

注意事项

  1. ROLLUP 生成的分组集是从最详细到最不详细的层次结构

  2. 列的顺序会影响结果,ROLLUP(a,b,c) 与 ROLLUP(c,b,a) 结果不同

  3. 在 MySQL 中,ROLLUP 不能与 ORDER BY 一起使用(除非使用 LIMIT)

ROLLUP 是生成层次化报表的强大工具,特别适合需要多级汇总的商业报表场景。

相关推荐
噼里啪啦啦.5 分钟前
Spring事务和事务传播机制
数据库·sql·spring
搬码红绿灯12 分钟前
MySQL主从复制深度解析:原理、架构与实战部署指南
数据库·mysql·架构
呼拉拉呼拉14 分钟前
Redis高可用架构
数据库·redis·架构·高可用架构
却尘14 分钟前
当全世界都在用 Rust 重写一切时,Prisma 却选择了反方向
前端·数据库·orm
藥瓿锻23 分钟前
2024 CKA题库+详尽解析| 15、备份还原Etcd
linux·运维·数据库·docker·容器·kubernetes·cka
李少兄29 分钟前
解决 idea提示`SQL dialect is not configured` 问题
java·sql·intellij-idea
远方160936 分钟前
16-Oracle 23 ai-JSON-Relational Duality-知识准备
数据库·oracle·json
Wooden-Flute40 分钟前
七、数据库的完整性
数据库·oracle
珹洺1 小时前
数据库系统概论(十七)超详细讲解数据库规范化与五大范式(从函数依赖到多值依赖,再到五大范式,附带例题,表格,知识图谱对比带你一步步掌握)
java·数据库·sql·安全·oracle
TDengine (老段)1 小时前
TDengine 开发指南——无模式写入
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据