group by rollup

首先引用ITPUB上的总结:

rollup(a,b,c)----------------> 从右到底递减汇总
====>group by a,b,c   (减0次)
UNION ALL
====>group by a,b     (减1次)
UNION ALL
====>group by a       (减2次)
UNION ALL
====>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)
产生的分组种数:3 种;
第一种: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)
产生的分组种数:3 种;
第一种: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 A,B
第二种:group by NULL
返回结果集:为以上两种分组统计结果集的并集且未去掉重复数据。

例2:Group by rollup(A,(B,C))
产生的分组种数:3 种;
第一种:group by A,B,C
第二种:group by A
第三种:group by NULL
返回结果集:为以上三种分组统计结果集的并集且未去掉重复数据。

posted @ 2011-05-15 22:01  爱生活,爱编程  阅读(234)  评论(0编辑  收藏  举报