SELECT id
,class
,score
,rank
FROM (SELECT b.*
-- 定义用户变量 @rownum 来记录数据的行号。通过赋值语句 @rownum := @rownum + 1 来累加达到递增行号。
,@rownum := @rownum+1
-- 如果当前分组编号和上一次分组编号相同,则 @rank (对每一组的数据进行编号)值加1,否则表示为新的分组,从1开始
,IF(@pdept = b.class, @rank := @rank + 1, @rank := 1) AS rank
-- 定义变量 @pdept 用来保存上一次的分组id
,@pdept := b.class
-- 这里的排序不确定是否需要,保险点还是加上吧
FROM (SELECT * FROM test1 a ORDER BY a.class, a.score DESC) b
-- 初始化自定义变量值
,(SELECT @rownum :=0, @pdept := NULL, @rank:=0) c
-- 该排序必须,否则结果会不对
ORDER BY b.class, b.score DESC) result
order by class, rank;