gpt4 book ai didi

java - Jedis 过滤 hmset 中的值

转载 作者:可可西里 更新时间:2023-11-01 11:21:25 28 4
gpt4 key购买 nike

我在redis中有一些具有这个键结构的值

key:1:abc -> votes -> 0
-> name -> John

key:1:xyz -> votes -> 0
-> name -> Mary

key:1:def -> votes -> 1
-> name -> Larry

key:2:ijk -> votes -> 0
-> name -> apple

这就是我的键空间的样子。我正在使用 hmset 将内容存储在 redis 中。 “key:1”是一个占位符,用于标识特定空间中的不同用户,“key:1”之后的部分是“key:1”中每条记录的唯一区分符。我想写一些代码来过滤掉来自redis的数据,以获得所有投票数设置为0的记录。所以jedis代码的输出应该是这样的

key:1:abc -> votes -> 0
-> name -> John

key:1:xyz -> votes -> 0
-> name -> Mary

Larry 被过滤掉了。我正在研究 hmscan 以解决此问题,但不确定该命令的外观。关于我可以做些什么来获得该输出的任何线索?另外,您认为获得这个时间的时间复杂度是多少?

最佳答案

对此有多种解决方案,但首先想到的是使用辅助结构。

每次您将一个项目添加到 HASH 中时,您也会将此人的姓名添加到一个 SET 中:

> SADD zerocount "Larry"
(integer) 1
> SADD zerocount "Mary"
(integer) 1

每当您想要计数为零的名称列表时,您可以执行 SSCAN(为您提供分页):

> sscan zerocount 0
1) "0"
2) 1) "Mary"
2) "Larry"

例如,在您要增加 Larry 的值时,您将从集合中删除该值:

> srem zerocount "Larry"
1

SADD 对于每个添加的成员都是 O(N),在本例中为 O(1)。对于我们的场景,SSCANO(1),而 SREMO(1),在general O(N) 其中 N 是要删除的成员数。

关于java - Jedis 过滤 hmset 中的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29403166/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com