2

我正在尝试对 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)并不是理想的方法。那么,只有当点不同时,我将如何进行具体递增呢?

4

1 回答 1

1

所以工作解决方案最终是:

SET @rank=0;
SET @curr=0;
SELECT *, 
  @prev := @curr,
  @curr := points.points,
  @rank := IF(@prev = @curr, @rank, @rank+1) AS rank
FROM points;

非常感谢乔治引导我走向正确的方向!

于 2013-06-21T19:23:29.243 回答