成绩表 c_score
id | s_name(学生姓名) | c_name(课程名) | score(分数) |
sql检索每门课程的前5名学生的姓名和成绩
SELECT a.c_name,a.s_name,a.score FROM c_score a WHERE 5 >( SELECT COUNT(*) FROM c_score b WHERE b.c_name = a.c_name AND b.score > a.score) ORDER BY a.c_name;
sql执行顺序如下
1 从a表里取出一条数据(from c_score a执行),此时a.name 和a.score为一个定值,例如a.c_name='数学' a.score=80 a.s_name='张三'
2 进行子查询, SELECT COUNT(*) FROM c_score b WHERE b.c_name = a.c_name AND b.score < a.score 执行,计算出数学中比80分大的数量
3 WHERE 5 > 执行,如果第二步计算结果小于5,则表示比80分大的人数少于5人,张三至少是第五名,符合检索条件,反之不符合
4 对成绩表全部数据循环执行 1-3步,得出每门课的前五名
5 取符合前四步数据的c_name,s_name,score列
6 对结果按c_name 升序排列