mysql 聚合函数 (group by ,having)

聚合函数

定义:
例如SUM, COUNT, MAX, AVG,GROUP BY,HAVING,ORDER BY等。这些函数和其它函数的根本区别就是它们一般作用在多条记录上。 这样的函数叫做聚合函数。

含义:
这儿就介绍两个特别的吧,group by 和having。
group by:是将记录中的数据,按照条件进行分组。
**having:**having是分组(group by)后的筛选条件,分组后的数据组内再筛选,区别于where则是在分组前筛选。

例如有一张地区表,里面有地区名字及代码,有分区名字及代码,面积,人口数等。
通过使用GROUP BY 子句,可以让SUM 和 COUNT 这些函数对属于一组的数据起作用。
当你指定 GROUP BY region 时, 属于同一个region(地区)的一组数据将只能返回一行值.
也就是说,表中所有除region(地区)外的字段,只能通过 SUM, COUNT等聚合函数运算后返回一个值.

HAVING子句可以让我们筛选成组后的各组数据.
WHERE子句在聚合前先筛选记录.也就是说作用在GROUP BY 子句和HAVING子句前. 而 HAVING子句在聚合后对组记录进行筛选。

SELECT region, SUM(population), SUM(area)
FROM china
GROUP BY region
HAVING SUM(area)>1000000

或者:

SELECT region, population,aea
FROM china
GROUP BY region
HAVING count(*)>1

上面两句,因为使用了group by所以最后返回的任然是分组后的一条数据。

如果要查询所有重复的,可以写成下面的:

select * from china where regin in (
SELECT region, population,aea
FROM china
GROUP BY region
HAVING count(*)>1)
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值