码迷,mamicode.com
首页 > 其他好文 > 详细

高级分组group by 、 group by cube、 group by rollup 使用说明

时间:2017-05-11 14:33:35      阅读:216      评论:0      收藏:0      [点我收藏+]

标签:group by 、 group by cube、 group by rollup 、oracle

1、分别以job和deptno分组求和
select sum(sal),job,deptno from emp group by grouping sets(job,deptno);


2、2^n-1分组(n表示列的数量,如果有括号里面的括起来的多个列算一个列 举例:cube((a,b),c)n=2;cube(a,b) n=2;
select sum(sal) ,deptno,job from emp group by cube(deptno,job);
cube__>2^n
     --group by 0;
     --group by job
     --group by deptno
     --group by deptno,job


3、n+1次分组
select sum(sal) ,deptno,job from emp group by rollup(deptno,job);
rullup -->n+1
       --group by deptno,job;
       --group by deptno;
       --group by 0;


4、检测是否参加分组 grouping()
   select sum(sal) ,deptno,job,grouping(deptno),grouping(job) from emp group by cube(deptno,job);
查询的结果集 1 表示没有参与分组;0表示参与分


本文出自 “11215554” 博客,请务必保留此出处http://11225554.blog.51cto.com/11215554/1924321

高级分组group by 、 group by cube、 group by rollup 使用说明

标签:group by 、 group by cube、 group by rollup 、oracle

原文地址:http://11225554.blog.51cto.com/11215554/1924321

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