1、分别以job和deptno分组求和select sum(sal),job,deptno from emp group by grouping sets(job,deptno);2、2^n-1分
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表示参与分
--结束END--
本文标题: 高级分组group by 、 group by cube、 group by rollup 使用说明
本文链接: https://www.lsjlt.com/news/45574.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-05-03
2024-05-03
2024-05-03
2024-05-03
2024-05-03
2024-05-03
2024-05-03
2024-05-03
2024-05-03
2024-05-03
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0