1

根据项目的值是否包含特定的子字符串,从哈希中删除一堆项目的最有效方法是什么?据我所知,实际上并没有一种方法可以在一个简单的块中做到这一点。我必须从 Java 列表中获取该哈希的所有值,然后遍历该列表直到找到我需要的内容,然后从哈希中删除它的键,并一遍又一遍地重复相同的过程。

我尝试的另一种方法是将哈希项目的 id 引用放在单独的列表中,以便稍后通过一次调用,我可以获取应该删除的项目的 id 列表。这有点好,但是,我使用的 redis 实现(Jedis)仍然不支持删除多个哈希键,所以我再次束手无策。

Redis 不支持参照完整性,对吧?这意味着,好的,存储在 Redis 列表中的键是对哈希中项目的引用,所以如果我删除列表,则哈希中的相应项目将被删除。Redis 中没有类似的东西,对吧?

我将不得不经历这个循环并分别删除每个项目。我希望至少有一个类似块的东西,我可以收集所有 1000 个命令,并在一个完整的调用中发送它们,而不是 1000 个单独的调用。

4

2 回答 2

1
I wish at least there was something like a block,
where I could collect all 1000 commands, and send them in one entire call,
rather than 1000 separate ones.

这就是交易的用途:http ://redis.io/topics/transactions

使用管道可以让来自其他连接客户端的可能命令在管道命令之间发出,因为它只保证您的客户端发出命令而不等待回复,不保证原子性。

事务中的命令(即在MULTI / EXEC之间)是原子发出的,我认为这是您想要的。

于 2011-11-23T14:38:17.470 回答
0

删除 Redis 列表中的 id 不会影响 Redis 哈希字段。为了加快速度,请考虑流水线。绝地武士支持...

于 2011-11-23T10:29:09.903 回答