Oracle數(shù)據(jù)庫(kù)中如何用GROUPING SETS進(jìn)行分組自定義
以下的文章主要介紹的實(shí)施在Oracle GROUPING SETS進(jìn)行分組自定義的匯總,本文章主要是通過(guò)作者在實(shí)際操作中的經(jīng)驗(yàn),來(lái)講述在Oracle數(shù)據(jù)庫(kù)中正確使用GROUPING SETS分組自定義。
當(dāng)你與COUNT和SUM這類(lèi)總計(jì)函數(shù)一起使用GROUP BY語(yǔ)句時(shí),你一般得不到多級(jí)總數(shù)。GROUP BY中每個(gè)唯一的列組合生成一個(gè)總數(shù),但這些總數(shù)不會(huì)“累加”到更高一級(jí)的總數(shù)中。
要實(shí)現(xiàn)這一點(diǎn),你可以用GROUP BY ROLLUP或GROUP BY CUBE替代GROUP BY,不過(guò)它們會(huì)生成所有可能的總數(shù),而你可能不需要全部總數(shù)。對(duì)GROUP BY CUBE而言,將會(huì)生成2^n組總數(shù),這里的n是GROUP BY中列的數(shù)目。
查看下面的查詢,它使用了SH樣本模式:
- SELECT prod_id, cust_id, channel_id, SUM(quantity_sold)
- FROM sales
- WHERE cust_id < 3
- GROUP BY CUBE (prod_id, cust_id, channel_id)
這將生成8組總數(shù):
所有行的總和
每個(gè)通道,包括所有產(chǎn)品和顧客。
每個(gè)顧客,包括所有產(chǎn)品和通道。
每項(xiàng)產(chǎn)品,包括所有顧客和通道。
每個(gè)通道/顧客組合,包括所有產(chǎn)品。
每個(gè)通道/產(chǎn)品組合,包括所有顧客。
每個(gè)產(chǎn)品/顧客組合,包括所有通道。
每個(gè)產(chǎn)品、顧客和通道組合。
可能的組合非常多。GROUP BY CUBE中每增加一列,生成的總數(shù)就會(huì)翻一番。
可以用GROUP BY GROUPING SETS來(lái)代替GROUP BY CUBE。你可以應(yīng)用來(lái)指定你感興趣的總數(shù)組合。因?yàn)樗槐赜?jì)算它不需要集合(也不會(huì)產(chǎn)生太多結(jié)果),所以對(duì)SQL引擎來(lái)說(shuō)更為高效。
其格式為:
- GROUP BY GROUPING SETS ((list), (list) ... )
這里(list)是圓括號(hào)中的一個(gè)列序列,這個(gè)組合生成一個(gè)總數(shù)。要增加一個(gè)總和,必須增加一個(gè)(NUlL)分組集。
例如,如果只要生成每項(xiàng)產(chǎn)品(包括所有顧客和通道)和每個(gè)顧客/通道組合(包括所有產(chǎn)品)的總數(shù),可以輸入:
- SELECT prod_id, cust_id, channel_id, SUM(quantity_sold)
- FROM sales
- WHERE cust_id < 3
- GROUP BY GROUPING SETS (
- (prod_id), (cust_id, channel_id)
- );
這種方法將這個(gè)數(shù)據(jù)集生成的總數(shù)數(shù)量從180個(gè)減少到37個(gè),并幫助你著重回答你希望解答的問(wèn)題。以上的相關(guān)內(nèi)容就是對(duì)Oracle GROUPING SETS進(jìn)行分組自定義的匯總的介紹,望你能有所收獲。
【編輯推薦】
- 實(shí)現(xiàn)異地Oracle數(shù)據(jù)庫(kù)的數(shù)據(jù)同步步驟
- Oracle分頁(yè)查詢語(yǔ)句的實(shí)際應(yīng)用
- Oracle修改相關(guān)字段的幾種常用方法
- Oracle字符集中的一些問(wèn)題總結(jié)
- Oracle企業(yè)管理器11g獲合作伙伴青睞的原因