【MySQL】聚合函数和分组(查找)
- 聚合函数
- 分组
- 分组聚合
- 如何显示每个部门的平均工资和最高工资
- 显示每个部门的每种岗位的平均工资和最低工资
- 显示平均工资低于2000的部门和它的平均工资(SMITH员工不参与)
- where 和 having 的区别
聚合函数
函数 | 说明 |
---|---|
COUNT([DISTINCT] expr) | 返回查询到的数据的 数量 |
SUM([DISTINCT] expr) | 返回查询到的数据的 总和,不是数字没有意义 |
AVG([DISTINCT] expr) | 返回查询到的数据的 平均值,不是数字没有意义 |
MAX([DISTINCT] expr) | 返回查询到的数据的 最大值,不是数字没有意义 |
MIN([DISTINCT] expr) | 返回查询到的数据的 最小值,不是数字没有意义 |
分组
在select中使用group by 子句可以对指定列进行分组查询
分组聚合
分组聚合主要使用的是 group by 和 having子句。分组聚合需要注意的是要先进行分组,然后再聚合。
一共有三张表:
1.EMP:员工表
2.DEPT:部门表
3.SALGRADE:工资等级表
如何显示每个部门的平均工资和最高工资
select deptno,max(sal) 最高 ,avg(sal) 平均 from emp group by deptno;
显示每个部门的每种岗位的平均工资和最低工资
select deptno,job,avg(sal) 平均,min(sal) 最低 from emp group by deptno,job;
显示平均工资低于2000的部门和它的平均工资(SMITH员工不参与)
select deptno,job,avg(sal) myavg from emp where ename!='SMITH' group by deptno,job having myavg<2000;
where 和 having 的区别
where是过滤表中数据的,而having是过滤分组数据的。在分组之前需要先通过where来拿到所要用到的数据。