LeetCode:Database 95.查找成绩处于中游的学生

Posted Xiao Miao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode:Database 95.查找成绩处于中游的学生相关的知识,希望对你有一定的参考价值。

要求:写一个 SQL 语句,找出在 所有 测验中都处于中游的学生 (student_id, student_name)。

不要返回从来没有参加过测验的学生。返回结果表按照 student_id 排序。

成绩处于中游的学生是指至少参加了一次测验, 且得分既不是最高分也不是最低分的学生。

表: Student的结构

+---------------------+---------+
| Column Name         | Type    |
+---------------------+---------+
| student_id          | int     |
| student_name        | varchar |
+---------------------+---------+
student_id 是该表主键.
student_name 学生名字.

表: Exam的结构

+---------------+---------+
| Column Name   | Type    |
+---------------+---------+
| exam_id       | int     |
| student_id    | int     |
| score         | int     |
+---------------+---------+
(exam_id, student_id) 是该表主键.
学生 student_id 在测验 exam_id 中得分为 score.

Student 表:

+-------------+---------------+
| student_id  | student_name  |
+-------------+---------------+
| 1           | Daniel        |
| 2           | Jade          |
| 3           | Stella        |
| 4           | Jonathan      |
| 5           | Will          |
+-------------+---------------+

Exam 表:

+------------+--------------+-----------+
| exam_id    | student_id   | score     |
+------------+--------------+-----------+
| 10         |     1        |    70     |
| 10         |     2        |    80     |
| 10         |     3        |    90     |
| 20         |     1        |    80     |
| 30         |     1        |    70     |
| 30         |     3        |    80     |
| 30         |     4        |    90     |
| 40         |     1        |    60     |
| 40         |     2        |    70     |
| 40         |     4        |    80     |
+------------+--------------+-----------+

Result Table:

+-------------+---------------+
| student_id  | student_name  |
+-------------+---------------+
| 2           | Jade          |
+-------------+---------------+

对于测验 1: 学生 1 和 3 分别获得了最低分和最高分。
对于测验 2: 学生 1 既获得了最高分, 也获得了最低分。
对于测验 3 和 4: 学生 1 和 4 分别获得了最低分和最高分。
学生 2 和 5 没有在任一场测验中获得了最高分或者最低分。
因为学生 5 从来没有参加过任何测验, 所以他被排除于结果表。
由此, 我们仅仅返回学生 2 的信息。

SQL语句:
注:where后子查询尽量不要再多次过滤

#1.方法1
select student_id,student_name
from student 
where student_id in(select distinct student_id
from exam 
where student_id not in(
select distinct student_id
from(
select exam_id,student_id,score,max(score) over(partition by exam_id) as m1,
min(score) over(partition by exam_id) as m2
from exam 
)a 
where score=m1 or score=m2));
#2.方法2
with b as
(select  distinct student_id
from (select exam_id,student_id,score,max(score) over(partition by exam_id) as m1,
min(score) over(partition by exam_id) as m2
from exam )a 
where score=m1 or score=m2
)

select student_id,student_name
from student
where student_id not in(select * from b) and student_id in(select distinct student_id from exam);

以上是关于LeetCode:Database 95.查找成绩处于中游的学生的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode(数据库)- 查找成绩处于中游的学生

LeetCode:Database 108.查找拥有有效邮箱的用户

LeetCode:Database 108.查找拥有有效邮箱的用户

Map

LeetCode-95-不同的二叉搜索树II

LeetCode:Database 85.电影评分