[SQL挖掘机] - 窗口函数 - 合计: rollup

介绍:

rollup 是一种用于在 sql 查询中生成聚合数据的特殊操作。它可以创建包含子总计和总计的结果集,并可用于生成层次化报表或汇总数据。

rollup 操作在 group by 子句中使用,可以在查询结果中生成多级汇总数据。它会根据指定的列进行分组,并生成按照不同层级进行汇总的结果。

用法:

以下是一个简单的示例,说明了如何使用 rollup 操作:

select column1, column2, sum(value)
from table
group by rollup (column1, column2)
;

上述查询将生成包含多个级别的汇总数据,包括单个列的总计、两列的子总计和全部列的总计。具体生成的结果集如下所示:

  • 按 column1 和 column2 进行分组的每个组的聚合结果
  • 列 column1 的子总计(忽略 column2)
  • 列 column2 的子总计(忽略 column1)
  • 所有列的总计

通过使用 rollup,您可以一次性获取多个层次的汇总数据,无需编写多个查询或手动计算。
需要注意的是,在使用 rollup 时,查询结果中的 null 值表示该列对应的层级没有可用的数据。

rollup 提供了一种方便的方式来处理多级汇总的需求,尤其适用于生成层次化报表、分析数据或在 bi(商业智能)工具中进行数据汇总与分析。

举例:

当我们有一个销售数据的表格时,我们可以使用 rollup 来生成按不同层级进行汇总的结果。假设我们有以下的 sales 表格:

+---------+-------+--------+
| Country | Region | Sales  |
+---------+-------+--------+
| USA     | West  | 100    |
| USA     | East  | 200    |
| USA     | North | 150    |
| Canada  | West  | 120    |
| Canada  | East  | 180    |
| Mexico  | North | 250    |
+---------+-------+--------+

现在我们想要按照国家、地区和整体进行销售汇总。我们可以运行以下查询来实现:

select country, region, sum(sales)
from sales
group by rollup (country, region)
;

执行上述查询后,将会生成下面的结果集:

+---------+-------+--------+
| Country | Region | Sales  |
+---------+-------+--------+
| Canada  | East  | 180    |
| Canada  | West  | 120    |
| Canada  | NULL  | 300    |
| Mexico  | North | 250    |
| Mexico  | NULL  | 250    |
| USA     | East  | 200    |
| USA     | North | 150    |
| USA     | West  | 100    |
| USA     | NULL  | 450    |
| NULL    | NULL  | 1000   |
+---------+-------+--------+

在结果中,我们可以看到:

  • 在最低层级,我们看到了每个国家和地区的销售数据。
  • 在第二层级,我们可以看到每个国家的子总计。
  • 在最顶层级,我们看到了整体的总计。

通过 rollup,我们能够一次性获取不同层级的综合数据,更方便地分析和汇总销售数据。

猜你喜欢

转载自blog.csdn.net/qq_40249337/article/details/132049196