oracle GROUP BY rollup
rollup:为每个分组返回一个小计,同时为所有分组返回总计;
SQL> select emp_id,month,prd_type_id,amount
2 from all_sales
3 where emp_id=21
4 order by emp_id,month ;
EMP_ID MONTH PRD_TYPE_ID AMOUNT
---------- ---------- ----------- ----------
21 1 4 3034.84
21 1 3 6034.84
21 1 2 1034.84
21 1 5
21 1 1 10034.84
21 2 3 1944.65
21 2 4 2944.65
21 2 1 15144.65
注:表中数据太多,只显示了一部分。
表all_sales存放2003年每个员工每个产品每个月的销量,
SQL> select emp_id,month,sum(amount)
2 from all_sales
3 where emp_id=21
4 group by emp_id,month
5 order by month ;
EMP_ID MONTH SUM(AMOUNT)
---------- ---------- -----------
21 1 20139.36
21 2 21578.6
21 3 30251.32
21 4 35729.8
21 5 25358.24
21 6 28258.56
21 7 36449.36
21 8 62639.28
21 9 49418.28
21 10 80016.76
21 11 41018.92
21 12 36139.36
用ROLLUP 进行分组
SQL> select emp_id,month,sum(amount)
2 from all_sales
3 where emp_id=21
4 group by rollup(emp_id,month) ;
EMP_ID MONTH SUM(AMOUNT)
---------- ---------- -----------
21 1 20139.36
21 2 21578.6
21 3 30251.32
21 4 35729.8
21 5 25358.24
21 6 28258.56
21 7 36449.36
21 8 62639.28
21 9 49418.28
21 10 80016.76
21 11 41018.92
21 12 36139.36
21 466997.84
466997.84
ROLLUP(emp_id,month):先对每个EMP_id的每个月的销量
进行分组求和,相当于GROUP BY EMP_ID,MONTH,得出这个员工,
每个月的销量总和,然后求这个员工一年所有的销量,相当于
GROUP BY EMP_ID,最后所求所有员工的销量总和,
因为查询限制只返回EMP_ID=21的数据,所以
最后两条记录的值相同。
group by rollup(emp_id,month) 与group by emp_id,month
不同之处在于是,group by rollup(emp_id,month) 求得每个员工的
月销量之后,又多做了两个工作,一是求得每个员一年所有的销量,
二是求所有员工的年总销量。
如果除去where emp_id=21,则最后一条记录返回所有员工的总销量,如:
SQL> select emp_id,month,sum(amount)
2 from all_sales
3 group by rollup(emp_id,month) ;
EMP_ID MONTH SUM(AMOUNT)
---------- ---------- -----------
21 1 20139.36
21 2 21578.6
21 3 30251.32
21 4 35729.8
21 5 25358.24
21 6 28258.56
21 7 36449.36
21 8 62639.28
21 9 49418.28
21 10 80016.76
21 11 41018.92
21 12 36139.36
21 466997.84
22 1 21939.36
22 2 21078.6
23 6 15658.56
23 7 33649.3
23 11 30518.92
23 12 24139.36
23 323077.84
24 1 14669.36
24 2 28878.6
24 3 35651.32
24 10 30116.76
24 11 22621.92
24 12 24139.36
24 333370.84
25 1 7269.36
25 2 13678.6
25 11 12821.92
25 12 12639.36
25 187970.84
26 1 16568.75
26 11 14821.38
26 12 15639.37
26 228769.93
1972485.13
数据太多,只显示一部分。
可以看出,group by rollup(emp_id,month) 为每个员工的销量进行了
汇总,得出了月销量和年销量(每个员工的最后一条),同时为所有员工进行了汇总,得出所有
员工的年总销量(最后一条记录)
函数:grouping
接收列作为参数,如果列为空,则grouping返回1,否则返回0,该函数与rollup搭配使用。
可以使用grouping函数对上述查询进行处理。
SQL> SELECT DECODE(GROUPING(EMP_ID), 1, '所有员工', EMP_ID) EMP_ID,
2 nvl2(emp_id,DECODE(GROUPING(MONTH), 1, '员工年度', MONTH),'所有员工年度') ND,
3 SUM(AMOUNT)
4 FROM ALL_SALES
5 GROUP BY ROLLUP(EMP_ID, MONTH)
6 ;
EMP_ID ND SUM(AMOUNT)
---------------------------------------- ---------------------------------------- -----------
21 1 20139.36
21 2 21578.6
21 3 30251.32
21 12 36139.36
21 员工年度 466997.84
26 7 12549.36
26 8 23139.28
26 9 19318.28
26 10 26116.99
26 11 14821.38
26 12 15639.37
26 员工年度 228769.93
所有员工 所有员工年度 1972485.13
oracle GROUP BY rollup的更多相关文章
- oracle group by rollup,decode,grouping,nvl,nvl2,nullif,grouping_id,group_id,grouping sets,RATIO_TO
干oracle 047文章12当问题,经验group by 声明.因此邂逅group by rollup,decode,grouping,nvl,nvl2,nullif,RATIO_TO_REPOR ...
- Oracle Group by+rollup+cube 的应用
首先我们创建一个示例表: Create table test_group (v_name varchar2(4) ,v_size varchar2(4) ,v_color varchar2(4) ,n ...
- oracle group by rollup实现小计、合计
SQL合计汇总实现数据N+1条显示: 注意group by rollup((ename, job, empno))!!! select decode(grouping(ename) + groupin ...
- oracle group by中cube和rollup字句的使用方法及区别
oracle group by中rollup和cube的区别: Oracle的GROUP BY语句除了最基本的语法外,还支持ROLLUP和CUBE语句. 如果是ROLLUP(A, B, C)的话,先 ...
- [Oracle] Group By 语句的扩展 - Rollup、Cube和Grouping Sets
常常写SQL语句的人应该知道Group by语句的主要使用方法是进行分类汇总,以下是一种它最常见的使用方法(依据部门.职位分别统计业绩): SELECT a.dname,b.job,SUM(b.sal ...
- oracle按照指定列分组合计group by rollup()
group by rollup() 按分组合计 select grouping(status),status,owner,object_type,count(*) from dba_objects w ...
- Oracle:grouping和rollup
Oracle grouping和rollup简单测试 SQL,,,) group by department_id order by department_id; DEPARTMENT_ID SUM( ...
- GROUP BY ROLLUP和CUBE 用法
ROLLUP和CUBE 用法 Oracle的GROUP BY语句除了最基本的语法外,还支持ROLLUP和CUBE语句. 如果是Group by ROLLUP(A, B, C)的话 ...
- Oracle分析函数 — sum, rollup, cube, grouping用法
本文通过例子展示sum, rollup, cube, grouping的用法. //首先建score表 create table score( class nvarchar2(20), course ...
随机推荐
- codeforces 463C. Gargari and Bishops 解题报告
题目链接:http://codeforces.com/contest/463/problem/C 题目意思:要在一个 n * n 大小的棋盘上放置两个bishop,bishop可以攻击的所有位置是包括 ...
- laravel基础课程---3、路由(Laravel中的常见路由有哪几种)
laravel基础课程---3.路由(Laravel中的常见路由有哪几种) 一.总结 一句话总结: 6种:post,get,put,patch,delete,options Route::get($u ...
- nyoj 269 VF
VF 时间限制:1000 ms | 内存限制:65535 KB 链接:NYOJ269 原创在:点击打开链接 题意:1-1000000000之间,各位数字之和等于给定s的数的个数. 每行给出一个数s ...
- 【C/C++】计算两个整数的最大公约数和最小公倍数
算法一 任何>1的整数都可以写成一个或多个素数因子乘积的形式,且素数乘积因子以非递减序出现. 则整数x,y可以分别标记为:x=p1x1p2x2...pmxm y=p1y1p2y2...pmym ...
- Chapter3——进入Android Dalvik虚拟机(二)
Dalvik汇编语言基础 Dalvik虚拟机为自己设计了一套指令集,并制定了自己的指令格式和调用规范. 位描述约定如下: 每16位的字采用空格分隔开来 每个字母表示4位,每个字母按顺序从高字节开始,排 ...
- Linux vSphere SDK for Perl 执行脚本报错
本人在gentoo系统上安装完vSphere for Perl之后,执行/usr/lib/vmware-viperl/app/vm/vminfo.pl脚本. 提示错误如下: Server vers ...
- 使用 WinSCP(下载) 上文件到 Linux图文教程
问题导读: 1.如何远程链接? 2.如何上传文件? 3.如何对立面的文件进行操作? 4.什么情况下会链接失败? https://yunpan.cn/cYWtNMycjeVPv 访问密码 4f7 ...
- Python框架下django 的并发和多线程
django 的并发能力真的是令人担忧,django本身框架下只有一个线程在处理请求,任何一个请求阻塞,就会影响另一个情感求的响应,尤其是涉及到IO操作时,基于框架下开发的视图的响应并没有对应的开启多 ...
- POJ1904(有向图缩点+输入输出挂参考)
King's Quest Time Limit: 15000MS Memory Limit: 65536K Total Submissions: 8311 Accepted: 3017 Cas ...
- 5.js屏蔽方向键,兼容IE和firefox
document.onkeydown=function(e){ e=e||event; //屏蔽向左的方向键 if(e.keyCode==37){ alert('禁止向左的方向键!'); return ...