zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

Mysql强化练习-难题之查询所有课程的成绩第2名到第3名的学生信息及该课程成绩

mysql 查询 信息 所有 练习 课程 学生 强化
2023-09-27 14:27:52 时间

在这里插入图片描述
– 22、查询所有课程的成绩第2名到第3名的学生信息及该课程成绩

SELECT t1.* FROM
(SELECT st.*,c.c_id,c.c_name,sc.s_score FROM student st
LEFT JOIN score sc ON sc.s_id=st.s_id
INNER JOIN course c ON c.c_id =sc.c_id AND c.c_id="01"
ORDER BY sc.s_score DESC LIMIT 1,2) t1

UNION ALL

SELECT t2.* FROM
(SELECT st.*,c.c_id,c.c_name,sc.s_score FROM student st
LEFT JOIN score sc ON sc.s_id=st.s_id
INNER JOIN course c ON c.c_id =sc.c_id AND c.c_id="02"
ORDER BY sc.s_score DESC LIMIT 1,2) t2

UNION ALL

SELECT t3.* FROM
(SELECT st.*,c.c_id,c.c_name,sc.s_score FROM student st
LEFT JOIN score sc ON sc.s_id=st.s_id
INNER JOIN course c ON c.c_id =sc.c_id AND c.c_id="03"
ORDER BY sc.s_score DESC LIMIT 1,2) t3

这是一道mysql难题,也是经典题,搞懂这题就懂得一类题了.

逐条解析
1.从学生表当中选择

SELECT t1.* FROM (student) 

2.将学生表和分数表连接从中选择学生信息,课程id,课程名字,分数

SELECT st.*,c.c_id,c.c_name,sc.s_score FROM student st
LEFT JOIN score sc ON sc.s_id=st.s_id

3.将学生表和课程表连接,倒序
,抽取第2,第3名
,且课程id为 01的课程信息
并按分数归类

INNER JOIN course c ON c.c_id =sc.c_id AND c.c_id="01"
ORDER BY sc.s_score DESC LIMIT 1,2

猜你喜欢:
– 25、查询各科成绩前三名的记录

– 42、查询每门功成绩最好的前两名