题目描述
(通过次数137,817 | 提交次数278,910,通过率49.41%)
表:Courses +-------------+---------+ | Column Name | Type | +-------------+---------+ | student | varchar | | class | varchar | +-------------+---------+ (student, class)是该表的主键列。 该表的每一行表示学生的名字和他们注册的班级。 编写一个SQL查询来报告 至少有5个学生 的所有班级。 以 任意顺序 返回结果表。 查询结果格式如下所示。 示例 1: 输入: Courses table: +---------+----------+ | student | class | +---------+----------+ | A | Math | | B | English | | C | Math | | D | Biology | | E | Math | | F | Computer | | G | Math | | H | Math | | I | Math | +---------+----------+ 输出: +---------+ | class | +---------+ | Math | +---------+ 解释: -数学课有6个学生,所以我们包括它。 -英语课有1名学生,所以我们不包括它。 -生物课有1名学生,所以我们不包括它。 -计算机课有1个学生,所以我们不包括它。 来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/classes-more-than-5-students
//测试数据 Create table If Not Exists Courses (student varchar(255), class varchar(255)); insert into Courses (student, class) values ('A', 'Math'); insert into Courses (student, class) values ('B', 'English'); insert into Courses (student, class) values ('C', 'Math'); insert into Courses (student, class) values ('D', 'Biology'); insert into Courses (student, class) values ('E', 'Math'); insert into Courses (student, class) values ('F', 'Computer'); insert into Courses (student, class) values ('G', 'Math'); insert into Courses (student, class) values ('H', 'Math'); insert into Courses (student, class) values ('I', 'Math');
解题思路
Courses表中保存了每个班级的每一名学生。
题目要求:查询出至少有5名学生的班级。
首先,我们需要计算出每个班级的学生人数,使用GROUP BY+COUNT可以实现。
然后,过滤出学生人数大于等于5的班级。
一般来说,可以在第一步的结果集外套一层子查询,然后使用WHERE子句来过滤。不过,我们也可以使用HAVING子句,从汇总统计结果中直接过滤出需要的数据。这种写法更简洁、更高效。
参考SQL
未特别说明的情况下,参考SQL为基于MySQL8.0实现。
select class from Courses group by class having count(1)>=5;
本站所有内容均为原创,本站保留所有权利。仅允许非商业用途的转载,但必须注明来源网站、作者、来源链接!否则,由此造成的一切后果,由转载方承担!
干货分享、技术提升、面试笔试、学习交流,欢迎关注公众号:xuesql。QQ学习交流群:209942678。