a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數據庫 > Oracle > 正文

Oracle分組函數之ROLLUP的基本用法

2020-07-26 13:58:21
字體:
來源:轉載
供稿:網友

rollup函數

本博客簡單介紹一下oracle分組函數之rollup的用法,rollup函數常用于分組統計,也是屬于oracle分析函數的一種

環境準備

create table dept as select * from scott.dept;create table emp as select * from scott.emp;

業務場景:求各部門的工資總和及其所有部門的工資總和

這里可以用union來做,先按部門統計工資之和,然后在統計全部部門的工資之和

select a.dname, sum(b.sal) from scott.dept a, scott.emp b where a.deptno = b.deptno group by a.dnameunion allselect null, sum(b.sal) from scott.dept a, scott.emp b where a.deptno = b.deptno;

上面是用union來做,然后用rollup來做,語法更簡單,而且性能更好

select a.dname, sum(b.sal) from scott.dept a, scott.emp b where a.deptno = b.deptno group by rollup(a.dname);

業務場景:基于上面的統計,再加需求,現在要看看每個部門崗位對應的工資之和

select a.dname, b.job, sum(b.sal) from scott.dept a, scott.emp b where a.deptno = b.deptno group by a.dname, b.jobunion all//各部門的工資之和select a.dname, null, sum(b.sal) from scott.dept a, scott.emp b where a.deptno = b.deptno group by a.dnameunion all//所有部門工資之和select null, null, sum(b.sal) from scott.dept a, scott.emp b where a.deptno = b.deptno;

用rollup實現,語法更簡單

select a.dname, b.job, sum(b.sal) from scott.dept a, scott.emp b where a.deptno = b.deptno group by rollup(a.dname, b.job);

假如再加個時間統計的,可以用下面sql:

select to_char(b.hiredate, 'yyyy') hiredate, a.dname, b.job, sum(b.sal) from scott.dept a, scott.emp b where a.deptno = b.deptno group by rollup(to_char(b.hiredate, 'yyyy'), a.dname, b.job);

cube函數

select a.dname, b.job, sum(b.sal) from scott.dept a, scott.emp b where a.deptno = b.deptno group by cube(a.dname, b.job);

cube

函數是維度更細的統計,語法和rollup類似

假設有n個維度,那么rollup會有n個聚合,cube會有2n個聚合

rollup統計列

rollup(a,b) 統計列包含:(a,b)、(a)、()

rollup(a,b,c) 統計列包含:(a,b,c)、(a,b)、(a)、()

....

cube統計列

cube(a,b) 統計列包含:(a,b)、(a)、(b)、()

cube(a,b,c) 統計列包含:(a,b,c)、(a,b)、(a,c)、(b,c)、(a)、(b)、(c)、()

....

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 综合网激情五月 | 狠狠操综合网 | 成人a视频 | 日韩中文在线视频 | 久久久国产精品入口麻豆 | 国产精品久久久久久一级毛片 | 精品国产乱码久久久久久闺蜜 | 国内精品在线视频 | av免费观看网页 | 一区二区三区四区在线 | 婷婷色综合 | 久在线 | 欧美福利影院 | 亚洲视频一区二区三区 | 中文字幕亚洲一区 | 成人在线黄色 | 成人欧美一区二区三区黑人孕妇 | 中文 日韩 欧美 | 欧美日韩国产综合视频 | 一区二区久久久 | 免费看的毛片 | 精品一区二区三区免费视频 | 国产精品自产拍在线观看桃花 | 精品久久久久久久久久久久包黑料 | 日韩福利在线 | 久久久看片| 看毛片网站 | 欧美精品不卡 | 鲁一鲁影院 | 一级毛片大全免费播放 | 国产一区在线观看视频 | 欧美一级大片 | 久久久精品一区 | 亚洲狠狠爱一区二区三区 | 久久精品免费观看 | 国产高清免费视频 | 国产精品自产av一区二区三区 | 久久免费精品视频 | 亚洲一区 中文字幕 | 日韩色av | 国产精品久久久久久久久久久久久久 |