我正在尝试对 SQL 选择中的点进行排名,但是只有当这些点与返回结果中的其他点不相关时。
我正在使用的 SQL 查询:
SET @rank=0;
SELECT *, @rank:=@rank+1 AS rank FROM points;
非常简单!它显示以下结果:
id | user_id | points | rank
----------------------------
2 | 133845 | 220 | 1
3 | 134084 | 220 | 2
4 | 1 | 150 | 3
5 | 134086 | 145 | 4
6 | 134080 | 100 | 5
7 | 17938 | 30 | 6
8 | 83011 | 20 | 7
9 | 26 | 5 | 8
10 | 134077 | 5 | 9
11 | 134074 | 5 | 10
如您所见,ID 2 和 3 具有相同数量的点数,ID 9、10 和 11 也是如此。因此从技术上讲,它们的排名应该相同,而不是继续增加。
下面的示例是表格的正确外观:
id | user_id | points | rank
----------------------------
2 | 133845 | 220 | 1
3 | 134084 | 220 | 1
4 | 1 | 150 | 2
5 | 134086 | 145 | 3
6 | 134080 | 100 | 4
7 | 17938 | 30 | 5
8 | 83011 | 20 | 7
9 | 26 | 5 | 8
10 | 134077 | 5 | 8
11 | 134074 | 5 | 8
我意识到在选择中不断增加每行的排名(使用@rank+1)并不是理想的方法。那么,只有当点不同时,我将如何进行具体递增呢?