#DQL语言
##五、分组函数
###分组函数分类:
sum 求和
avg 平均值
max 最大值
min 最小值
count 计算个数
####一、简单的使用
例子:SELECT SUM(salary) 和,AVG(salary) 平均,MAX(salary) 最高,MIN(salary) 最低,COUNT(salary) 个数 FROM employees;
####二、使用的特点
1.sum、avg一般用于处理数值型
如select sum(last_name) from employees;
就不行,结果为0
max、min、count可以处理任何类型
2.以上分组函数都忽略null值
如SELECT COUNT(commission_pct) FROM employees;
→35
统计的就是非空(非null值)的个数!!!
3.和distinct搭配
select count(distinct salary) from employees;
→57
代表有57种不同的工资
当然,sum、avg等等也都可以和distinct搭配使用。
4.count函数的用法
①count(某一字段):表示统计该字段的非null值
如:SELECT COUNT(commission_pct) FROM employees;
→35
表示不为null值的奖金率个数是35个
②count(*):表示统计表的总行数
③count(1):表示在表中加了一列数‘1’,然后统计该列中‘1’的个数,相当于还是在统计表的总行数,和count()有些类似,但涉及到查询效率问题,我给一个网址,有兴趣的同学可以去了解一下,这里我就不多讲了
count(1)和count()区别:https://www.cnblogs.com/zxf330301/p/10217350.html
效率:
MYISAM存储引擎下,count()的效率最高;
INNODB存储引擎下,count()和count(1)的效率差不多,比count(字段)效率更高一些。(所以我们一般用count(*)去统计行数)
案例:查询部门编号为90的员工个数
SELECT
COUNT(*)
FROM
employees
WHERE
department_id = 90;
5.和分组函数一同查询的字段要求是group by后的字段(group by后面会讲)
假设这样一种情况,看这个语句:
SELECT AVG(salary),employee_id FROM employees;
我们可以看到AVG(salary)的结果为单个值,但employee_id的值有多个,这样的表格显然会是不完整的,故而会报错。
以上就是分组函数的内容,下一节将介绍分组查询!