mysql之聚合函数、group by、having

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

那么聚合函数有哪些呢?函数

COUNT    统计行数量spa

SUM         求某一列的和blog

AVG          求某一列的平均值排序

MAX    求某一列的最大值class

MIN     求某一列的最小值im

下面给出一些具体的用法d3

首先建立数据表以下:统计

执行列、行计数(count):数据

COUNT  标准格式:

SELECT COUNT(<计数规范>)  FROM 表名;

其中,计数规范包括

-* : 计算全部选择的的行,包括NULL的值

- ALL列名 : 计数全部指定列的非空值,若是不写,就默认为ALL

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

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

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

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

也能够计算班级数目,须要用到DISTINCT:

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

 返回列合计值(SUM):

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

计算学生的年龄之和:

返回列的平均值(AVG):

计算学生年龄的平均值

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

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

 

 

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

数据分组  (GROUP BY )

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

好比咱们想知道每一个班里有几个学生,咱们可使用 GTOUP BY 配合  COUNT 使用:

 注意:由于聚合函数经过做用于一组数据而只返回一个单个值,所以,在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便可完成:
相关文章
相关标签/搜索