什么是分组查询?
在实际的应用中,可能有这样的需求,需要先进行分组,然后对每一组的数据进行操作。这个时候我们需要使用分组查询,怎么进行分组查询呢? select ... from ... group by ... 计算每个部门的工资和? 计算每个工作岗位的平均薪资? 找出每个工作岗位的最高薪资? ....
将之前的关键字全部组合在一起,他们的执行顺序? select ... from ... where ... group by ... order by ...
以上关键字的顺序不能颠倒,需要记住。执行顺序是什么? 1.from 2.where 3.group by 4.select 5.order by
为什么分组函数不能直接使用在where后面? select ename,sal from emp where sal > min(sal);//报错。 因为分组函数在使用的时候必须先分组之后才能使用。 where执行的时候,还没有分组。所以where后面不能出现分组函数。
select sum(sal) from emp; 这个没有分组,为啥sum()函数可以用呢?因为select在group by之后执行。
找出每个工作岗位的工资和? 实现思路:按照工作岗位分组,然后对工资求和。 select job,sum(sal) from emp group by job;
+-----------+----------+ | job | sum(sal) | +-----------+----------+ | ANALYST | 6000.00 | | CLERK | 4150.00 | | MANAGER | 8275.00 | | PRESIDENT | 5000.00 | | SALESMAN | 5600.00 | +-----------+----------+ 以上这个语句的执行顺序? 先从emp表中查询数据。 根据job字段进行分组。 然后对每一组的数据进行sum(sal)
重点结论: 在一条select语句当中,如果有group by语句的话, select后面只能跟:参加分组的字段,以及分组函数。 其它的一律不能跟。
找出“每个部门,不同工作岗位”的最高薪资?
两个字段联合分组select deptno, job, max(sal) from emp group by deptno, job;
使用having对分组后的数据进一步过滤
having不能单独使用,having不能代替where,having必须和group by联合使用。
找出每个部门最高薪资,要求显示最高薪资大于3000的?
select deptno, max(sal) from emp group by deptno having max(sal) > 3000;
单表查询大总结
select ... from ... where ... group by ...having ... order by ...
执行顺序?
1.from
2.where
3.group by
4.having
5.select
6.order by
找出除MANAGER岗位之外,每个岗位的平均薪资,要求显示平均薪资大于1500的, 要求按照平均薪资降序排。
select job, avg(sal) from emp where job != 'MANAGER' group by job having avg(sal) > 1500 order by avg(sal);