亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:5日期:2023-11-26 08:46:39
本文通過文章作者的親身經(jīng)歷來講解如何在Oracle數(shù)據(jù)庫中使用GROUPING SETS分組自定義。 當你與COUNT和SUM這類總計函數(shù)一起使用GROUP BY語句時,你一般得不到多級總數(shù)。GROUP BY中每個唯一的列組合生成一個總數(shù),但這些總數(shù)不會“累加”到更高一級的總數(shù)中。 要實現(xià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ù): 所有行的總和 每個通道,包括所有產(chǎn)品和顧客。 每個顧客,包括所有產(chǎn)品和通道。 每項產(chǎn)品,包括所有顧客和通道。 每個通道/顧客組合,包括所有產(chǎn)品。 每個通道/產(chǎn)品組合,包括所有顧客。 每個產(chǎn)品/顧客組合,包括所有通道。 每個產(chǎn)品、顧客和通道組合。 可能的組合非常多。GROUP BY CUBE中每增加一列,生成的總數(shù)就會翻一番。 可以用GROUP BY GROUPING SETS來代替GROUP BY CUBE。你可以應用來指定你感愛好的總數(shù)組合。因為它不必計算它不需要集合(也不會產(chǎn)生太多結果),所以對SQL引擎來說更為高效。 其格式為: GROUP BY GROUPING SETS ((list), (list) ... )這里(list)是圓括號中的一個列序列,這個組合生成一個總數(shù)。要增加一個總和,必須增加一個(NUlL)分組集。 例如,假如只要生成每項產(chǎn)品(包括所有顧客和通道)和每個顧客/通道組合(包括所有產(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));這種方法將這個數(shù)據(jù)集生成的總數(shù)數(shù)量從180個減少到37個,并幫助你著重回答你希望解答的問題。
主站蜘蛛池模板: 亚洲精品国产专区91在线 | 国产在线观看成人免费视频 | 亚洲精品资源网在线观看 | 国产成人精品999在线 | 久久久久在线视频 | 日本高清视频一区二区 | 四虎午夜剧场 | 成人午夜看片在线观看 | 欧美白人和黑人xxxx猛交视频 | 喷潮白浆| 久草网站| 在线一区免费播放 | 欧美高清一区二区三 | 日韩在线第一区 | 亚洲二三区 | 中文字幕在线免费观看视频 | 永久免费毛片手机版在线看 | 亚洲精品久一区 | 亚洲在线视频观看 | 毛片在线免费播放 | 在线看毛片网站 | 欧美视频亚洲 | 日本草草视频在线观看 | 国内交换一区二区三区 | 欧美成a人免费观看久久 | 一区二区三区影院 | 精品国产a | 韩国一级永久免费观看网址 | 欧美性色黄大片在线观看 | 免费看日韩欧美一级毛片 | 亚洲欧美一区二区三区国产精品 | 中文字幕在亚洲第一在线 | 久草在线2 | 九九精品免视频国产成人 | 狠狠色丁香婷婷久久综合不卡 | 男人天堂视频在线观看 | 精品高清国产a毛片 | 国产一级一级毛片 | 国产成人精品免费久久久久 | 欧美手机手机在线视频一区 | 99九九精品免费视频观看 |