如何在mysql中计算排名?

时间:2012-06-17 14:47:02

标签: mysql

我有一个'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,因为有两名学生的分数比这些人多。

如何编写查询以计算排名,如上所示?

1 个答案:

答案 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;

看看这个小提琴:http://sqlfiddle.com/#!2/2c7e5/32/0