- 聚合函数是用来做纵向运算的函数:
COUNT():统计指定列不为NULL的记录行数;
MAX():计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;
MIN():计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;
SUM():计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;
AVG():计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;
COUNT
当需要纵向统计时可以使用COUNT()。
- 查询emp表中记录数:
SELECT COUNT(*) AS cnt FROM emp;
- 查询emp表中有佣金的人数:
SELECT COUNT(comm) cnt FROM emp;
注意:因为count()函数中给出的是comm列,那么只统计comm列非NULL的行数。
- 查询emp表中月薪大于2500的人数:
SELECT COUNT(*) FROM emp
WHERE sal > 2500;
- 统计月薪与佣金之和大于2500元的人数:
SELECT COUNT(*) AS cnt FROM emp WHERE sal+IFNULL(comm,0) > 2500;
- 查询有佣金的人数,以及有领导的人数:
SELECT COUNT(comm), COUNT(mgr) FROM emp;
SUM和AVG
当需要纵向求和时使用sum()函数。
- 查询所有雇员月薪和:
SELECT SUM(sal) FROM emp;
- 查询所有雇员月薪和,以及所有雇员佣金和:
SELECT SUM(sal), SUM(comm) FROM emp;
- 查询所有雇员月薪+佣金和:
SELECT SUM(sal+IFNULL(comm,0)) FROM emp;
- 统计所有员工平均工资:
SELECT AVG(sal) FROM emp;
MAX和MIN
- 查询最高工资和最低工资:
SELECT MAX(sal), MIN(sal) FROM emp;