Redis 的 Set 数据结构不支持直接的交集运算,但你可以通过执行一些额外的命令来实现这个功能
- 将两个集合转换为列表:
SMEMBERS set1 SMEMBERS set2
- 使用
LINTERNSET
命令找到两个列表的交集:
LINTERNSET list1 list2
- 将结果转换回集合:
SMEMBERS intersection_set
- (可选)将结果集转换回列表,以便进一步处理:
LRANGE intersection_set 0 -1
这是一个简单的例子,假设我们有两个集合 set1
和 set2
,我们想要找到它们的交集并将结果存储在 intersection_set
中:
SMEMBERS set1 SMEMBERS set2 LINTERNSET list1 list2 SMEMBERS intersection_set
如果你想要批量处理多个集合的交集,可以使用 Lua 脚本来实现更高效的操作。这是一个示例 Lua 脚本,用于计算两个集合 key1
和 key2
的交集并将结果存储在 destination_key
中:
local intersection_set = {} local set1 = redis.call('SMEMBERS', KEYS[1]) local set2 = redis.call('SMEMBERS', KEYS[2]) for _, value in ipairs(set1) do if redis.call('SREM', KEYS[2], value) then table.insert(intersection_set, value) end end return intersection_set
你可以使用 EVAL
命令执行此脚本:
EVAL script 2 set1 set2 destination_key
这将返回一个包含交集元素的列表。