2

我有一个表'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

由于 student_id 为 1 和 3 的两个学生的分数最高为 5,因此他们被排在第 1 位。对于分数为 2 的学生,排名为 3,因为有两个学生的分数高于这些人。

如上所示,我们如何编写查询来计算排名?

4

1 回答 1

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

于 2012-06-17T19:57:16.207 回答