聚合函数
定义:
例如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)