我有一个'student_marks'表,其中有两列'student_id'和'mark':
student_id | marks
-------------------
1 | 5
2 | 2
3 | 5
4 | 1
5 | 2
我需要计算与标记对应的等级。上表的预期输出是:
student_id | marks | rank
-------------------------
1 | 5 | 1
2 | 2 | 3
3 | 5 | 1
4 | 1 | 5
5 | 2 | 3
由于两名学生_1和3的学生得分最高,他们被排在第1级。对于有2分的学生,等级为3,因为有两名学生的分数比这些人多。
如何编写查询以计算排名,如上所示?
答案 0 :(得分:3)
这应该有效,尽管它对变量很重要。
SELECT student_id, mark, rank FROM (
SELECT t.*,
@rownum := @rownum + 1 AS realRank,
@oldRank := IF(mark = @previous,@oldRank,@rownum) AS rank,
@previous := mark
FROM student_marks t,
(SELECT @rownum := 0) r,
(SELECT @previous := 100) g,
(SELECT @oldRank := 0) h
ORDER BY mark DESC
) as t
ORDER BY student_id;