久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:2日期:2023-11-26 08:46:39
本文通過(guò)文章作者的親身經(jīng)歷來(lái)講解如何在Oracle數(shù)據(jù)庫(kù)中使用GROUPING SETS分組自定義。 當(dāng)你與COUNT和SUM這類總計(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 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ù)就會(huì)翻一番。 可以用GROUP BY GROUPING SETS來(lái)代替GROUP BY CUBE。你可以應(yīng)用來(lái)指定你感愛(à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 salesWHERE cust_id < 3GROUP BY GROUPING SETS ((prod_id), (cust_id, channel_id));這種方法將這個(gè)數(shù)據(jù)集生成的總數(shù)數(shù)量從180個(gè)減少到37個(gè),并幫助你著重回答你希望解答的問(wèn)題。
主站蜘蛛池模板: 亚洲精品一区二区三区樱花 | 亚洲精品久久久一区二区三区 | 成人在线免费视频 | 亚洲国产精品一区 | 欧美视频二区 | 国产视频三区 | julia一区二区三区中文字幕 | 亚洲第一网站 | 日韩视频国产 | 成人在线看片网站 | 国产一区二区视频在线 | 午夜成人免费视频 | 免费一级黄色电影 | 久久av网| 久热伊人 | 一级片欧美 | 亚洲九九 | 久久99这里只有精品 | 久久精品久久久 | 欧美激情一区二区 | 国产精品二区三区 | 国产麻豆乱码精品一区二区三区 | 国产精品久久久久久久午夜 | 精品成人在线视频 | 美女视频一区 | 国产91网址| 亚洲精品视频在线 | 日韩欧美国产精品一区二区三区 | 久久国产电影 | 免费的av网站 | 欧美成人精品一区 | 国产精品久久久精品 | 国产激情在线看 | 国产一二三视频 | 日本在线一区二区三区 | 亚洲成人精品 | 国产在线观看av | 天天综合7799精品影视 | 中文字幕一区在线 | 欧美精品在线一区二区三区 | 亚洲一区 中文字幕 |