天天看点

group by rollup

首先引用ITPUB上的总结:

rollup(a,b,c)----------------> 从右到底递减汇总

====>group by a,b,c   (减0次)

UNION ALL

====>group by a,b     (减1次)

====>group by a       (减2次)

====>group by null(全部汇总) (全部减掉)

移动了4次,所以有4个级别的汇总,列移动的顺序就是从右到左的,3个列的rollup就有4个group by汇总

这个总结简单明了。

一、group by 后带rollup子句所产生的效果

group by 后 带 rollup 子句的功能可以理解为:先按一定的规则产生多种分组,然后按各种分组统计数据(至于统计出的数据是求和还是最大值还是平均值等这就取决于SELECT后的聚合函数)。因此要搞懂group by 后带rollup子句的用法主要是搞懂它是如何按一定的规则产生多种分组的。另group by后带 rollup 子句所返回的结果 

集,可以理解为各个分组所产生的结果集的并集且没有去掉重复数据。

1、对比没有带rollup 的goup by

例:Group by A,B

产生的分组种数:1种;

即group by A,B

返回结果集:也就是这一种分组的结果集。

2、带rollup但group by与rollup之间没有任何内容

例1:Group by rollup(A,B)

产生的分组种数:3 种;

第一种:group by A,B

第二种:group by A

第三种:group by NULL

(说明:本没有group byNULL的写法,在这里指是为了方便说明,而采用之。含义是:没有分组,也就是所有数据做一个统计。例如聚合函数是SUM的话,那就是对所有满足条件的数据进行求和。此写法的含义下同)

返回结果集:为以上三种分组统计结果集的并集且未去掉重复数据。

例2:Group by rollup(A,B,C)

产生的分组种数:4 种;

第一种:group by A,B,C

第二种:group by A,B

第三种:group by A

第四种:group by NULL

返回结果集:为以上四种分组统计结果集的并集且未去掉重复数据。

3、带rollup但group by与rollup之间还包含有列信息

例1:Group by A , rollup(A ,B)

第一种:group by A,A,B 等价于 group by A,B

第二种:group by A,A    等价于 group by A

第三种:group by A,NULL  等价于 group by A

例2:Group by C,rollup(A,B)

第一种:group by C,A,B

第二种:group by C,A

第三种:group by C,NULL 等价于 group by C

4、带rollup且rollup子句括号内又使用括号对列进行组合

例1:Group by rollup((A,B))

产生的分组种数:2 种;

第二种:group by NULL

返回结果集:为以上两种分组统计结果集的并集且未去掉重复数据。

例2:Group by rollup(A,(B,C))

继续阅读