用Redis排序集实现密集排名

时间:2013-10-07 23:21:45

标签: redis ranking sortedset

我正在尝试使用排名实现排行榜,数据在Redis中存储为排序集。我试图弄清楚的部分是如何实现密集(即“1-2-2-3”)排名,例如,用户排名如此:

Score   User    Rank
---------------------
22      user1   1
21      user2   2
21      user3   2
21      user4   2
20      user5   3
20      user6   3

这个答案:https://stackoverflow.com/a/14944280/2177几乎是我所需要的,但它相当于“1-2-2-4”排名,这对我的应用来说是不可取的,例如:

1-2-2-4 Ranking 
Score   User    Rank
---------------------
22     user1    1
21     user2    2
21     user3    2
21     user4    2
20     user5    5
20     user6    5

这似乎是一个相当常见的用例。有没有人在Redis中成功实现过这样的事情,如果有的话,怎么做?

1 个答案:

答案 0 :(得分:1)

我最终做的是添加第二个排序集,其中只包含唯一的分数,然后我可以在密集排名中查询各自的位置。