聚集函数与数据分组

前言

我们经常需要汇总数据,而不需要实际数据的本身。为此,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排除的行不包括在分组中。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值