1. GROUP BY 子句

GROUP BY 函数就是 SQL 中用来实现分组的函数,其用于结合聚合函数,能根据给定数据列的每个成员对查询结果进行分组统计,最终得到一个分组汇总表。
实例:
描述
请编写 SQL 语句,查询教师表 teachers,统计不同年龄教师的人数,并将结果按照年龄从大到小排列,返回列名显示为 age_count。

表定义: teachers (教师表)
在这里插入图片描述
SQL语句:

SELECT  `age`,COUNT(`age`) AS `age_count`
FROM `teachers`
GROUP BY `age`
ORDER BY `age` desc;

2. HAVING 子句

我们在使用 WHERE 条件子句时会发现其不能与聚合函数联合使用,为解决这一点,SQL 中提供了 HAVING 子句。在使用时, HAVING 子句经常与 GROUP BY 联合使用,HAVING 子句就是对分组统计函数进行过滤的子句。

HAVING 子句对于 GROUP BY 子句设置条件的方式其实与 WHERE 子句与 SELECT 的方式类似,语法也相近,但 WHERE 子句搜索条件是在分组操作之前,而 HAVING 则是在之后。
实例:
请编写 SQL 语句,查询 teachers 表中,各个国家所有教师的平均年龄大于所有国家教师的平均年龄的教师信息。
表定义: teachers (教师表)
在这里插入图片描述
SQL语句:

SELECT * FROM teachers
WHERE country=any(SELECT country FROM teachers
GROUP BY `country` HAVING AVG(age)>(SEL
ECT AVG(age) FROM teachers));
Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐