登录
首页 >  Golang >  Go问答

实时更新 Redis 排序集中的元素排名

来源:stackoverflow

时间:2024-03-08 14:33:24 304浏览 收藏

学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《实时更新 Redis 排序集中的元素排名》,以下内容主要包含等知识点,如果你正在学习或准备学习Golang,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

问题内容

在我的 Go 程序中,我正在使用一个名为 MyEntries 的 Redis 排序集,它包含三个元素:EntryAEntryBEntryC,排名为 12 和 3(等等..)。

它都是有序的,并且元素是唯一的(这就是我使用列表的原因)。

但是问题是当如果删除一个元素时,排名顺序显然不再是这样!例如,如果我删除 EntryBEntryC 的排名仍为 3(而不是 2)。

我知道我基本上可以通过索引进行查询,因为索引号会动态变化。但不幸的是,我刚刚发现 Redis 无法通过元素名称查询索引。

您能帮我解决这个问题吗?如果删除一个元素,Redis 有没有办法动态更新排序集中的排名?

PS 我正在构建一个 FIFO 排队程序,该程序使用户能够从队列中删除元素(除了最早的元素先离开)。您还想知道您在队列中的位置(这就是我面临此排名更新问题的原因)。


解决方案


您可以放置​​标识排名的 score,而不是放置排名。

如果用户a的分数为100b的分数为200等.

127.0.0.1:6379> zadd mysort 100 a 200 b 300 c 500 d 50 e
(integer) 5
127.0.0.1:6379> zrevrange mysort 0 -1 withscores
 1) "d"
 2) "500"
 3) "c"
 4) "300"
 5) "b"
 6) "200"
 7) "a"
 8) "100"
 9) "e"
10) "50"
127.0.0.1:6379> zrevrank mysort d
(integer) 0
127.0.0.1:6379> zrevrank mysort e
(integer) 4
127.0.0.1:6379> zrem mysort b
(integer) 1
127.0.0.1:6379> zrevrank mysort e
(integer) 3
127.0.0.1:6379> zrem mysort d
(integer) 1
127.0.0.1:6379> zrevrange mysort 0 -1 withscores
1) "c"
2) "300"
3) "a"
4) "100"
5) "e"
6) "50"
127.0.0.1:6379> zrevrank mysort e
(integer) 2
127.0.0.1:6379> zadd mysort 500 q 25 f 350 p
(integer) 3
127.0.0.1:6379> zrevrange mysort 0 -1 withscores
 1) "q"
 2) "500"
 3) "p"
 4) "350"
 5) "c"
 6) "300"
 7) "a"
 8) "100"
 9) "e"
10) "50"
11) "f"
12) "25"
127.0.0.1:6379> zrevrank mysort q
(integer) 0

在这里,您不断地将元素添加到带有分数的排序集中,分数越高意味着排名越低 - 当您使用 zrevrank 时,最高分数将为 0。当您使用 zrem 删除得分最高的元素时,得分第二高的元素将按照 0 的值排名最高。

理论要掌握,实操不能落!以上关于《实时更新 Redis 排序集中的元素排名》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>