mysql条件是聚合函数_mysql之聚合函数、group by、having

sql中提供聚合函数可以用来统计,求和,求最值等

那么聚合函数有哪些呢?

COUNT    统计行数量

SUM         求某一列的和

AVG          求某一列的平均值

MAX    求某一列的最大值

MIN     求某一列的最小值

下面给出一些具体的用法

首先创建数据表如下:

c23849799fe36f0e1081fec1c750143f.png

执行列、行计数(count):

COUNT  标准格式:

SELECT COUNT()  FROM 表名;

其中,计数规范包括

-* : 计算所有选择的的行,包括NULL的值

- ALL列名 : 计数所有指定列的非空值,如果不写,就默认为ALL

- DISTINCT 列名 : 计数指定的列的唯一非空值

例如,计算班里有多少学生:

8129c006fc235c1d091bb054db7f1110.png

这样就出错了,会把null值也算进来,可以这样来计算:

6c892dff10bca0ea10162bb2deddd520.png

也可以加入条件筛选,例如计算女生的人数

7a8bb7203ce173ac41151bd5e278e4cc.png

也可以计算班级数目,需要用到DISTINCT:

1e21cda074c4acc617b82233b3d9096e.png

DISTINCT 即去重,如果不加DISTINCT返回的结果会是4

返回列合计值(SUM):

注:SUM 只有 ALL 和 DISTINST 俩种计数规范, 并没有*

计算学生的年龄之和:

385e464d41b08647a8ee16b6f28aaf80.png

返回列的平均值(AVG):

计算学生年龄的平均值

c70e7fbce0571da14128aacda50ce4ba.png

返回最大值/最小值(MAX/MIN):

求年龄最大的学生(最小年龄同理)

aea0c2af2685769deeb7d7a0d69f157a.png

注:这里只能求最大值,不能查询学生的具体信息,需要用到子查询

数据分组  (GROUP BY )

SQL数据可以按照列名分组,配合聚合函数十分实用

比如我们想知道每个班里有几个学生,我们可以使用 GTOUP BY 配合  COUNT 使用:

c01c07b51446ddba15d660aa3e454d11.png

注意:因为聚合函数通过作用于一组数据而只返回一个单个值,因此,在SELECT语句中出现的元素要么为一个聚合函数的输入值,要么为GROUP BY语句的参数,否则会出错。

HAVING 过滤条件

HAVING语句通常与GROUP BY语句联合使用,用来过滤由GROUP BY语句返回的记录集。HAVING语句的存在弥补了WHERE关键字不能与聚合函数联合使用的不足。

再说HAVING之前先要讲一下sql的执行顺序:

第一步: 执行FROM

第二步: 执行WHERE过滤条件

第三步: 执行GROUP BY 分组

第四步: 执行SELECT投影

第五步: 执行HAVING过滤条件

第六步: 执行ORDER BY排序

例,我们想查询平均年龄在20岁以上的班级

能用下面的语句吗?

SELECT student_class, AVG(student_age) FROM t_student WHERE AVG(student_age)>20 GROUP BY student_class;

结果会出错。正因为聚合函数在WHERE之后执行,所以这里在WHERE判断条件里加入聚合函数是做不到的。

这里使用HAIVING即可完成:

b45c3c7ad9928229422eb8fea06fd2e6.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值