GROUP BY,WHERE,HAVING之间的区别和用法

“Where” 是一个约束声明,使用Where来约束来之数据库的数据,Where是在结果返回之前起作用的,且Where中不能使用聚合函数。

“Having”是一个过滤声明,是在查询返回结果集以后对查询结果进行的过滤操作,在Having中可以使用聚合函数。

在说区别之前,得先介绍GROUP BY这个子句,而在说GROUP子句前,又得先说说“聚合函数”——SQL语言中一种特殊的函数。例如SUM, COUNT, MAX, AVG等。

这些函数和其它函数的根本区别就是它们一般作用在多条记录上。

如:

SELECT SUM(population) FROM vv_t_bbc ;

   这里的SUM作用在所有返回记录的population字段上,结果就是该查询只返回一个结果,即所有国家的总人口数。
 
   而通过使用GROUP BY 子句,可以让SUM 和 COUNT 这些函数对属于一组的数据起作用。当你指定 GROUP BY region 时,只有属于同一个region(地区)的一组数据才将返回一行值,也就是说,表中所有除region(地区)外的字段,只能通过 SUM, COUNT等聚合函数运算后返回一个值。

下面再说说“HAVING”和“WHERE”:
   HAVING子句可以让我们筛选成组后的各组数据,WHERE子句在聚合前先筛选记录.也就是说作用在GROUP BY子句和HAVING子句前;而HAVING子句在聚合后对组记录进行筛选。where>group by >having

  让我们还是通过具体的实例来理解GROUP BY 和 HAVING 子句:

  SQL实例:

  一、显示每个地区的总人口数和总面积:

SELECT region, SUM(population), SUM(area)
FROM bbc
GROUP BY region

  先以region把返回记录分成多个组,这就是GROUP BY的字面含义。分完组后,然后用聚合函数对每组中的不同字段(一或多条记录)作运算。

  二、显示每个地区的总人口数和总面积.仅显示那些人口数量超过1000000的地区。

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

[注]在这里,我们不能用where来筛选超过1000000的地区,因为表中不存在这样一条记录。相反,HAVING子句可以让我们筛选成组后的各组数据.

ps:如果想根据sum后的字段进行排序可以在后面加上:order by sum(population) desc/asc

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 SQL 中,Group By 语句是用来根据一定的规则将一个数据集划分成若干个小的区域,然后针对这些小区域进行数据处理的。通过 Group By 子句可以对结果集中的数据进行分组,并且可以结合聚合函数使用,如求平均值、求和等。而 Having 子句则是在 Group By 子句之后使用的,用于筛选分组后的结果集中的数据。 具体的使用方法如下: 1. Group By 语句的用法:在 SQL 查询语句中,通过 Group By 子句后面跟上需要分组的列名,可以按照这些列的值进行分组。例如,可以使用以下语句对表中的数据按照某个字段进行分组: SELECT column_name, aggregate_function(column_name) FROM table_name GROUP BY column_name; 2. Having 语句的用法:在 Group By 语句之后使用 Having 子句可以对分组后的结果进行筛选,只输出满足条件的分组结果。例如,可以使用以下语句查找平均成绩大于某个值的学生: SELECT sno, AVG(grade) FROM sc GROUP BY sno HAVING AVG(grade) > 80; 需要注意的是,Where 子句和 Having 子句的作用对象不同。Where 子句作用于表和视图,用于在分组和聚集计算之前选取输入行;而 Having 子句作用于分组结果,用于在分组和聚集之后选取满足条件的分组行。因此,Where 子句不能包含聚合函数,而 Having 子句总是包含聚合函数。 综上所述,Group By 语句用于对数据进行分组处理,Having 子句用于筛选分组结果。通过组合使用 Group By 和 Having 子句,可以实现对分组后的数据进行更精细的筛选和汇总。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值