首页 > 数据库技术 > 详细

SQL 分组(group by和having)

时间:2021-02-02 19:58:45      阅读:27      评论:0      收藏:0      [点我收藏+]

https://blog.csdn.net/xiao1_1bing/article/details/81109353

首先,创建数据表如下:

技术分享图片

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 分组(group by和having)

原文:https://www.cnblogs.com/sunny3158/p/14363716.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!