SQL分组(groupby和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);
groupby是什么函数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 排序

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。