7.1 分组函数

#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的值有多个,这样的表格显然会是不完整的,故而会报错。

以上就是分组函数的内容,下一节将介绍分组查询!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值