牛骨文教育服务平台(让学习变的简单)
博文笔记

mysql 聚合函数 (group by ,having)

创建时间:2016-09-12 投稿人: 浏览次数:4453

聚合函数

定义:
例如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)
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。