国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

Oracle中用GROUPING SETS分組自定義匯總

2024-08-29 13:51:41
字體:
供稿:網(wǎng)友
本文通過文章作者的親身經(jīng)歷來講解如何在Oracle數(shù)據(jù)庫中使用GROUPING SETS分組自定義。 當(dāng)你與COUNT和SUM這類總計(jì)函數(shù)一起使用GROUP BY語句時(shí),你一般得不到多級總數(shù)。GROUP BY中每個(gè)唯一的列組合生成一個(gè)總數(shù),但這些總數(shù)不會“累加”到更高一級的總數(shù)中。 要實(shí)現(xiàn)這一點(diǎn),你可以用GROUP BY ROLLUP或GROUP BY CUBE替代GROUP BY,不過它們會生成所有可能的總數(shù),而你可能不需要全部總數(shù)。對GROUP BY CUBE而言,將會生成2^n組總數(shù),這里的n是GROUP BY中列的數(shù)目。 查看下面的查詢,它使用了SH樣本模式: SELECT PRod_id, cust_id, channel_id, SUM(quantity_sold)FROM salesWHERE cust_id < 3GROUP 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ù)就會翻一番。 可以用GROUP BY GROUPING SETS來代替GROUP BY CUBE。你可以應(yīng)用來指定你感愛好的總數(shù)組合。因?yàn)樗槐赜?jì)算它不需要集合(也不會產(chǎn)生太多結(jié)果),所以對SQL引擎來說更為高效。 其格式為: GROUP BY GROUPING SETS ((list), (list) ... )這里(list)是圓括號中的一個(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 salesWHERE cust_id < 3GROUP BY GROUPING SETS ((prod_id), (cust_id, channel_id));這種方法將這個(gè)數(shù)據(jù)集生成的總數(shù)數(shù)量從180個(gè)減少到37個(gè),并幫助你著重回答你希望解答的問題。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 台东县| 萍乡市| 邯郸县| 哈尔滨市| 年辖:市辖区| 辉南县| 航空| 苍南县| 新邵县| 久治县| 平安县| 株洲市| 惠来县| 阿鲁科尔沁旗| 长白| 日喀则市| 米易县| 宁都县| 平凉市| 昌邑市| 株洲市| 同仁县| 合川市| 玉龙| 尚义县| 洞口县| 阜康市| 睢宁县| 云浮市| 都昌县| 乾安县| 顺义区| 奎屯市| 缙云县| 准格尔旗| 固始县| 扎囊县| 肥乡县| 特克斯县| 泗阳县| 嘉荫县|