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

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表示参与分

相关文章

这篇文章主要介绍“hive和mysql的区别是什么”,在日常操作中...
这篇“MySQL数据库如何改名”文章的知识点大部分人都不太理解...
这篇文章主要介绍“mysql版本查询命令是什么”的相关知识,小...
本篇内容介绍了“mysql怎么修改字段的内容”的有关知识,在实...
这篇文章主要讲解了“mysql怎么删除unique约束”,文中的讲解...
今天小编给大家分享一下mysql怎么查询不为空的字段的相关知识...