在MYSQL中生成排名的最佳方法是什么?

unk*_*ser 6 mysql sql

除了MYSQL中的行数据之外,获得行级别的最佳方法是什么?

例如,假设我有一份学生名单,我想在GPA中排名.我知道我可以通过GPA订购,但是有什么最快的方式让MYSQL在我回来的rowdata中返回等级?

Wil*_*del 6

这将返回学生的排名,学生ID和GPA.

set @rownum := 0;
SELECT @rownum := @rownum + 1 AS rank, student_id, gpa 
    FROM `students` ORDER BY gpa DESC
Run Code Online (Sandbox Code Playgroud)


Vin*_*vic 5

这将返回排名为 rownum

SELECT @rownum := @rownum + 1 rownum, 
       t.* 
  FROM (SELECT @rownum:=0) r, 
       (SELECT * FROM students ORDER BY gpa DESC) t;
Run Code Online (Sandbox Code Playgroud)

  • 这是一个单一的声明.威廉是两个单独的陈述.这就是它更复杂的原因. (2认同)