练习需要用到的数据库文件
链接:https://pan.baidu.com/s/1wu7IOrmyYRLMy1V3JekZqA
提取码:667g
分组函数
功能:做统计使用,又称为统计函数,聚合函数,组函数
分类:
sum 求和
avg 平均值
max 最大值
min 最小值
count 计算个数
特点
1.sum,avg 一般用于处理数值类型
max,min,count可以处理任何类型
2.分组函数是否忽略null值
全部忽略null值
3.可以和 distinct 搭配实现去重运算
4.count函数的单独使用
一般用count(*)用作统计行数
5.和分组函数一同查询的字段要求是group by 后的字段
简单使用
SELECT SUM(salary) FROM employees;
SELECT AVG(salary) FROM employees;
SELECT MAX(salary) FROM employees;
SELECT MIN(salary) FROM employees;
SELECT COUNT(salary) FROM employees;
SELECT AVG(salary) 和 ,AVG(salary) 平均... FROM employees;
2.特点
参数支持哪些类型
SELECT SUM(last_name) FROM employees; #不可以
SELECT MAX(last_name),MIN(hiredate) FROM employees; #可以
SELECT COUNT(last_name) FROM employees; #可以
3. 是否忽略null值
SELECT SUM(comminssion_pct) FROM employees;
SELECT MAX(commission_pct),MIN(commission_pct) FROM employees;
4.和distinct 搭配
SELECT SUM(DISTINCT salary),SUM(salary) FROM employees;
SELECT COUNT(DISTINCT salary),COUNT(salary) FROM employees;
5.count函数详细介绍
SELECT COUNT(salary) FROM employees;
SELECT COUNT(*) FROM employees; #行数
SELECT COUNT(1) FROM employees; #统计行数
效率:
MYISAM 存储引擎下 ,count(*)效率最高,推荐使用
INNODB 存储引擎下 ,count(*)和count(1)的效率差不多,比count(字段)要高一些
6. 和分组函数一同查询字段有限制
SELECT AVG(salary),employee_id FROM employees; #无意义