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
返回結果集:為以上三種分組統計結果集的并集且未去掉重復數據。
轉載于:https://www.cnblogs.com/snake-hand/archive/2011/05/15/2452301.html
總結
以上是生活随笔為你收集整理的group by rollup的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: poj 2137
- 下一篇: 推荐:个人时间跟踪工具 ManicTim