分组函数:也叫"多行处理函数"或"聚合函数" (特点:输入多行,最终输出一行)
用于对表中指定字段下的内容进行统计的函数。
- count() 计数(返回指定字段下内容不为null的数据个数)
统计员工数量:
select count(ename) from emp;
count(*)是统计表中所有数据行的个数,它不考虑数据行是否存在null
select count(*) from emp;
查询有具体补助(补助不为null)的人员数量
select count(comm) from emp;
- sum() 求和
工资求和:
select sum(sal) from emp;
- avg() 平均数
计算平均工资:
select avg(sal) from emp;
max() 最大值
找出最高薪资:
select max(sal) from emp;
- min() 最小值
找出最低薪资:
select min(sal) from emp;
【注意:分组函数在使用的时候必须先进行分组,然后才能使用。如果没有分组,整张表默认为一组.】
分组函数在使用的时候需要注意几点:
第一:分组函数自动忽略null,不需要提前对null进行处理。
第二:count(具体字段):表示统计该字段下所有不为空的元素总个数。
count(*):表示统计表中总记录条数,因为在数据库中不能出现一条记录中所有的字段都
为null。
第三:分组函数不能直接使用在where子句中。
找出比平均工资高的员工信息:下面的命令语句是错误的(说完分组查询就明白了)
select ename,sal from emp where sal > avg(sal);(这样写命令是错误的)
这个问题可以通过子查询来解决:
select ename,sal from emp where sal > (select avg(sal) from emp);
第四:所有的分组函数可以组合起来一起用
select sum(sal),max(sal),min(sal),avg(sal),count(*) from emp;