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 过滤条件