码迷,mamicode.com
首页 > 数据库 > 详细

Oracle分组函数cube VS rollup

时间:2015-05-29 00:32:44      阅读:323      评论:0      收藏:0      [点我收藏+]

标签:

分析函数cube和rollup魅力
首先请看下面例子
1)创建表
create table group_test (group_id int, job varchar2(10), name varchar2(10), salary int);
2)初始化表
insert into group_test values (10,‘Coding‘, ‘Bruce‘,1000);
insert into group_test values (10,‘Programmer‘,‘Clair‘,1000);
insert into group_test values (10,‘Architect‘, ‘Gideon‘,1000);
insert into group_test values (10,‘Director‘, ‘Hill‘,1000);

insert into group_test values (20,‘Coding‘, ‘Jason‘,2000);
insert into group_test values (20,‘Programmer‘,‘Joey‘,2000);
insert into group_test values (20,‘Architect‘, ‘Martin‘,2000);
insert into group_test values (20,‘Director‘, ‘Michael‘,2000);

insert into group_test values (30,‘Coding‘, ‘Rebecca‘,3000);
insert into group_test values (30,‘Programmer‘,‘Rex‘,3000);
insert into group_test values (30,‘Architect‘, ‘Richard‘,3000);
insert into group_test values (30,‘Director‘, ‘Sabrina‘,3000);

insert into group_test values (40,‘Coding‘, ‘Samuel‘,4000);
insert into group_test values (40,‘Programmer‘,‘Susy‘,4000);
insert into group_test values (40,‘Architect‘, ‘Tina‘,4000);
insert into group_test values (40,‘Director‘, ‘Wendy‘,4000);

commit;

select t.group_id, sum(t.salary) from group_test t group by t.group_id order by 1;

技术分享技术分享
 3)查看rollup函数
select t.group_id, sum(t.salary) from group_test t group by rollup(t.group_id)order by 1; 
技术分享
 select t.group_id,job,  sum(t.salary) from group_test t group by rollup(t.group_id,job) order by 1;  
技术分享

4)查看cube函数
select t.group_id, sum(t.salary) from group_test t group by cube(t.group_id)order by 1;

技术分享

 由此可见rollup以及cude函数是group by函数的扩展,方便用来做小计的分析函数
仔细观察两个函数的细微差别
rollup(a,b)   统计列包含:(a,b)、(a)、()
rollup(a,b,c) 统计列包含:(a,b,c)、(a,b)、(a)、()
……以此类推ing……

cube(a,b)     统计列包含:(a,b)、(a)、(b)、()
cube(a,b,c)   统计列包含:(a,b,c)、(a,b)、(a,c)、(b,c)、(a)、(b)、(c)、()
……以此类推ing……
 
替换成原始的group by字句实际就是union all了不区分ID的一个小汇总。  
技术分享
技术分享

Oracle分组函数cube VS rollup

标签:

原文地址:http://www.cnblogs.com/longjshz/p/4537298.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!