@R星校长
第3
关:查询各科成绩并排序
本关任务:根据提供的表和数据,查询各科成绩,进行排序并显示排名,按学生编号(s_id
)、课程编号(c_id
)、学生成绩(s_score
)和排名(rank
)进行输出,具体效果请查看测试集。
student
表数据:
s_id | s_name | s_sex |
---|---|---|
01 | Mia | 女 |
02 | Riley | 男 |
03 | Aria | 女 |
04 | Lucas | 女 |
05 | Oliver | 男 |
06 | Caden | 男 |
07 | Lily | 女 |
08 | Jacob | 男 |
course
表数据:
c_id | c_name | t_id |
---|---|---|
01 | Chinese | 02 |
02 | Math | 01 |
03 | English | 03 |
teacher
表数据:
t_id | t_name |
---|---|
01 | 张三 |
02 | 李四 |
03 | 王五 |
score
表部分数据:
s_id | c_id | s_score |
---|---|---|
01 | 01 | 80 |
01 | 02 | 90 |
01 | 03 | 99 |
02 | 01 | 70 |
… | … | … |
开始你的任务吧,祝你成功!
答案:
根据题目描述,首先可以使用左联按各科成绩排序,并显示名次,左联计算空缺时,只要判断比自己高的,如果同分数,再判断学号高低,这样就可以得到合适的项了。
#请在此添加实现代码
########## Begin ##########
select a.* ,count(b.s_score)+1 rank from score a left join score b
on a.c_id = b.c_id and a.s_score < b.s_score
group by a.c_id,a.s_id
order by a.c_id,count(b.s_score);
########## End ##########