SQL系列四——分组(group by和having)

首先,创建数据表如下:

1、数据分组(GROUP BY):

SQL中数据可以按列名分组,搭配聚合函数十分实用。

例,统计每个班的人数: 

SELECT student_class,COUNT(ALL student_name) AS 总人数 FROM t_student GROUP BY (student_class);

AS为定义别名,别名的使用在组合及联接查询时会有很好的效果,之后再说。

分组中也可以加入筛选条件WHERE,不过这里一定要注意的是,执行顺序为:WHERE过滤→分组→聚合函数。牢记!

统计每个班上20岁以上的学生人数:

SELECT student_class,COUNT(student_name) AS 总人数 FROM t_student WHERE student_age >20 GROUP BY (student_class);

2、HAVING过滤条件:

之前说了分组操作、聚合函数、WHERE过滤的执行顺序,那如果我们希望在聚合之后执行过滤条件怎么办?

例,我们想查询平均年龄在20岁以上的班级

能用下面的语句吗?

SELECT student_class, AVG(student_age) FROM t_student WHERE AVG(student_age)>20 GROUP BY student_class;

结果会出错。正因为聚合函数在WHERE之后执行,所以这里在WHERE判断条件里加入聚合函数是做不到的。

这里使用HAIVING即可完成:

SELECT student_class,AVG(student_age) AS 平均年龄 FROM t_student GROUP BY (student_class) HAVING AVG(student_age)>20; 

 

这里再啰嗦一句

SQL的执行顺序:

–第一步:执行FROM

–第二步:WHERE条件过滤

–第三步:GROUP BY分组

–第四步:执行SELECT投影列,聚集函数

–第五步:HAVING条件过滤

–第六步:执行ORDER BY 排序

### SQL中的HAVINGGROUP BY子句 #### GROUP BY 子句的作用 `GROUP BY` 子句用于将查询的结果集按照一个或多个列分组,通常与聚合函数一起使用来计算每组的数据汇总信息。例如,在订单表中按会员ID (`member_id`) 进行分组可以统计每位会员下的不同订单数量。 ```sql SELECT member_id, COUNT(DISTINCT order_id) AS distinct_order_count FROM orders GROUP BY member_id; ``` 此语句会返回每个 `member_id` 及其对应的唯一订单数[^2]。 #### HAVING 子句的功能 `HAVING` 子句用来过滤由 `GROUP BY` 创建的各组数据。它类似于 `WHERE` 子句,但是作用于已经完成分组后的记录集合上,并且可以在条件表达式里包含聚合函数。这意味着如果想要基于某个聚合结果设置筛选标准,则必须通过 `HAVING` 来实现而不是 `WHERE`。 考虑这样一个场景:找出至少有两次购买行为的不同客户列表: ```sql SELECT member_id FROM orders GROUP BY member_id HAVING COUNT(order_id) >= 2; ``` 上述命令先依据 `member_id` 对订单进行了分类处理并计数;接着利用 `HAVING` 设置了一个门槛——只有那些拥有两个及以上订单条目的成员才会被选入最终输出结果集中[^1]。 #### 主要差异对比 - **应用时机**:`WHERE` 是在执行任何分组操作之前应用于单个行上的条件判断;而 `HAVING` 则是在完成了分组之后针对整个组进行进一步的选择。 - **支持的操作**:由于 `HAVING` 处理的是经过分组后的数据,因此它可以安全地运用各种类型的聚合函数作为逻辑运算的一部分,这正是 `WHERE` 所不具备的能力之一。 - **性能考量**:当不需要做额外的过滤时仅需保留必要的 `GROUP BY`,因为引入不必要的 `HAVING` 或者复杂的组合可能会降低查询效率。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值