什么是聚合函数
聚合函数在数据的查询分析中,应用十分广泛。聚合函数可以对数据求和、求最大值和最小值、求平均值等等。 求公司员工的平均月收入是多少? SELECT AVG (sal+IFNULL(comm,0)) FROM t_emp;
SUM函数
SUM函数用于求和,只能用于数字类型,字符类型的统计结果为0,日期类型统计结果是毫秒数相加。 SELECT SUM(ename) FROM t_emp;
SELECT SUM(sal) FROM t_emp WHERE deptno IN(10,20);
MAX函数
MAX函数用于获得非空值的最大值。 SELECT MAX(comm) FROM t_emp;
问题1: 查询10和20部门中,月收入最高的员工? SELECT MAX(sal+IFNULL(comm,0)) FROM t_emp WHERE deptno IN (10,20);
问题2: 查询员工名字最长的是几个字符? SELECT MAX(LENGTH(ename)) FROM t_emp;
MIN函数
MIN函|数用于获得非空值的最小值。 SELECT MIN(empno) FROM t_emp ;
SELECT MIN(hiredate) FROM t_emp ;
AVG函数
AVG函数用于获得非空值的平均值,非数字数据统计结果为0 SELECT AVG(sal+IFNULL(comm,0)) FROM t_emp;
SELECT AVG(ename) FROM t_emp;
COUNT函数
COUNT(*)
用于获得包含空值的记录数, COUNT(列名)
用于获得包含非空值的记录数 SELECT COUNT(*) FROM t_emp;
SELECT COUNT(comm) FROM t_emp;
练习
查询10和20部门中,底薪超过2000元并且工龄超过15年的员工人数?
SELECT COUNT ( * ) FROM t_emp
WHERE deptno IN ( 10 , 20 ) AND sal> 2000
AND DATEDIFF( NOW ( ) , hiredate) / 365 > 15 ;
查询1985年以后入职的员工,底薪超过公司平均底薪的员工数量?
SELECT COUNT ( * ) FROM t_emp
WHERE hiredate> "1985-01-01"
AND sal> ( SELECT AVG ( sal) FROM t_emp) ;