Đó có thể không phải là cách đẹp nhất, nhưng bạn có thể dễ dàng làm những việc như:
set @rank = 0;
set @prev = 0;
select id, score, IF (id = @prev, @rank := @rank + 1, @rank := 1), @prev := id
from scores
order by id, score;
Tôi đoán bạn cũng muốn báo cáo cập nhật và đó sẽ là:
set @rank = 0;
set @prev = 0;
update scores
set rank = IF(id = @prev, @rank := @rank + 1, @rank := 1),
id = (@prev := id)
order by id, score;