天天看點

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))

繼續閱讀