1 1 3 4排名方式
mysql> select * from score;
+----+-------+| id | Score |
+----+-------+
| 1 | 36.5 |
| 2 | 37.8 |
| 3 | 40.6 |
| 4 | 42.6 |
| 5 | 36.5 |
| 6 | 36.5 |
| 7 | 42.6 |
| 8 | 40.6 |
| 9 | 22.8 |
| 10 | 42.6 |
+----+-------+
10 rows in set
mysql> select t.score,(select count(s.score)+1 from score s where s.score>t.score) rank from score t order by t.score desc;
+-------+------+
| score | rank |
+-------+------+
| 42.6 | 1 |
| 42.6 | 1 |
| 42.6 | 1 |
| 40.6 | 4 |
| 40.6 | 4 |
| 37.8 | 6 |
| 36.5 | 7 |
| 36.5 | 7 |
| 36.5 | 7 |
| 22.8 | 10 |
+-------+------+
10 rows in set
1 1 2 3 排序方式
mysql> select t.score,(select count(s.score)+1 from (select s.score,count(s.score) from score s group by score order by score desc) s where s.score>t.score) rank from score t order by t.score desc;
+-------+------+
| score | rank |
+-------+------+
| 42.6 | 1 |
| 42.6 | 1 |
| 42.6 | 1 |
| 40.6 | 2 |
| 40.6 | 2 |
| 37.8 | 3 |
| 36.5 | 4 |
| 36.5 | 4 |
| 36.5 | 4 |
| 22.8 | 5 |
+-------+------+
10 rows in set
本文介绍两种MySQL中实现排名查询的方法,第一种适用于简单排名需求,相同分数并列排名;第二种适用于复杂场景,相同分数视为同一排名层级,但不跳过排名编号。
174万+

被折叠的 条评论
为什么被折叠?



