前言
我们经常需要汇总数据,而不需要实际数据的本身。为此,SQL给出了5个聚集函数。
聚集函数:对某些行运行的函数,计算并返回一个值。
数据分组可以将数据分为多个逻辑组。然后可以再对每个组进行聚集计算。
五个聚集函数
- AVG(): 返回某列的平均值。
- COUNT(): 返回某列的行数。
- MAX(): 返回某列的最大值。
- MIN(): 返回某列的最小值。
- SUM(): 返回某列值之和。
注意的点
- AVG()函数忽略列值为NULL的行。
- 使用COUNT(*)对表中行数进行统计时,不管列中包含的是空值(NULL)还是非空值,都会进行计数。
- 使用COUNT(column)对特定的列中具有值得行进行计数,忽略NULL值。
创建分组
select sid,count(*) as num
from students
group by sid;
因为使用了GROUP BY ,DBMS会自动完成数据分组,然后对每个组进行聚集操作。
GROUP BY 子句必须出现在WHERE子句之后,ORDER BY 子句之前。
过滤分组
select sid,count(*) as num
from students
group by sid;
having count(*) >= 1;
HAVING 和 WHERE 的差别:
**WHERE在数据分组前进行过滤,HAVING在数据分组后进行过滤。**WHERE排除的行不包括在分组中。