oracle group by中cube和rollup字句的使用方法及區別

zangqianglei發表於2015-05-12
oracle group by中rollup和cube的區別: 
Oracle的GROUP BY語句除了最基本的語法外,還支援ROLLUP和CUBE語句。如果是ROLLUP(A, B, C)的話, 
首先會對(A、B、C)進行GROUP BY,然後對(A、B)進行GROUP BY,然後是(A)進行GROUP BY,最後對全表進行GROUP BY操作。 
如果是GROUP BY CUBE(A, B, C),則首先會對(A、B、C)進行GROUP BY,然後依次是(A、B),(A、C),(A),(B、C),(B),(C), 
最後對全表進行GROUP BY操作。 

測試資料: 
/* 
Oracle的GROUP BY語句除了最基本的語法外,還支援ROLLUP和CUBE語句。 
*/ 
--建立表 
create table fzq 

    name varchar(20), 
    calss varchar(2), 
    kemu  varchar(4), 
    chengji varchar(3) 
    

--插入資料 
insert into fzq values 
('11','1','數學','90'); 
insert into fzq values 
('11','1','語文','68'); 
insert into fzq values 
('12','1','數學','90'); 
insert into fzq values 
('12','1','語文','88'); 
insert into fzq values 
('22','2','數學','70'); 
insert into fzq values 
('22','2','語文','88'); 
insert into fzq values 
('33','2','數學','95'); 
insert into fzq values 
('33','2','語文','98'); 

--測試SQL 
select * from fzq; 
select calss,name,sum(chengji) from fzq group by calss,name; 
select calss,name,sum(chengji) from fzq group by cube(calss,name) order by calss; 
select calss,name,sum(chengji) from fzq group by rollup(calss,name) order by calss; 
select calss,name,sum(chengji) from fzq group by grouping sets(calss,name); 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/25954236/viewspace-1651078/,如需轉載,請註明出處,否則將追究法律責任。

相關文章