0

Redis n00b 在这里所以不要拍!

我需要将一组集合存储在由键索引的 redis 中 - 我可以:

import redis
r = redis.Redis()

r.sadd("A:B:123", *{456, 789})
r.sadd("A:B:124", *{666, 777})

但是如果我想要集合“A:B”,我必须手动收集密钥,如下所示:

{k.rsplit(b':', 1)[-1]: r.smembers(k) for k in r.scan_iter("A:B:*") }
# {b'124': {b'666', b'777'}, b'123': {b'456', b'789'}}

这似乎非常慢(还要注意 rsplit)

我一直在尝试使用 hmset 来做到这一点:

r.hmset("A:B", mapping={123: 'X', 124: 'Z'})

但我找不到用我的集合代替“X”和“Z”的方法。

(请注意,理想情况下设置的元素应该是传入的 int 类型 - 另请注意,这些集合是只读的,所以我想优化查找而不是插入时间)

4

1 回答 1

1
import redis
r = redis.Redis()

r.sadd("A:B:123", *{456, 789})
r.sadd("A:B:124", *{666, 777})

新代码

import redis
r = redis.Redis()

r. hmset("A:B", {"123": ",".join(map(str, {456, 789}))})
r. hmset("A:B", {"124": ",".join(map(str, {666, 777}))})

打印所有元素

print(dict([(k,set(map(int, v.split(b",")))) for k,v in r.hgetall("A:B").items()]))

使用单个映射来存储相关的键,并在给定的键中将连接的值存储为字符串。

注意:将元素添加到 set 不是原子的,因为过程必须先读取然后执行反序列化并将其存储回来,除非使用 LUA 脚本。

使用 SUNION

r.sadd("A:B:123", *{456, 789})
r.sadd( "A:B:members", "A:B:123")
r.sadd("A:B:124", *{666, 777})
r.sadd( "A:B:members", "A:B:124")

打印方式

r.sunion(r.smembers("A:B:members"))
于 2021-01-20T18:48:36.810 回答