首先引用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))