一、概述
Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。
集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
二、常用命令
示例:sadd set val1...valn
用法:将一个或多个成员元素加入到集合中,已经存在于集合的成员元素将被忽略。假如集合 key 不存在,则创建一个只包含添 加的元素作成员的集合。当集合 key 不是集合类型时,返回一个错误。
返回:被添加到集合中的新元素的数量,不包括被忽略的元素。
示例:srem set val1...valn
用法:用于移除集合中的一个或多个成员元素,不存在的成员元素会被忽略。当 key 不是集合类型,返回一个错误。
返回:被成功移除的元素的数量,不包括被忽略的元素。
示例:smembers set
用法:返回集合中所有的元素,没有元素的是空集合
返回:集合中所有的成员
示例:scard set
用法:获取集合中成员的个数
返回:集合的数量。 当集合 key 不存在时,返回 0 。
示例:sdiff FIRST_KEY OTHER_KEY1..OTHER_KEYN
用法:返回给定集合之间的差集。不存在的集合 key 将视为空集。差集的结果来自前面的 FIRST_KEY ,而不是后面的 OTHER_KEY1,也不是整个 FIRST_KEY OTHER_KEY1..OTHER_KEYN 的差集。
返回:包含差集成员的列表。
127.0.0.1:6379> sadd key1 a b c
(integer) 3
127.0.0.1:6379> sadd keys c d e
(integer) 3
127.0.0.1:6379> sdiff key1 keys
1) "a"
2) "b"
127.0.0.1:6379>
示例:sunion set1 set2
用法:返回给定集合的并集。不存在的集合 key 被视为空集。
返回:并集成员列表
示例:smove source dest member
用法:将指定成员 member 元素从 source 集合移动到 destination 集合。SMOVE 是原子性操作。
如果 source 集合不存在或不包含指定的 member 元素,则 SMOVE 命令不执行任何操作,仅返回 0 。否则, member 元素从 source 集合中被移除,并添加到 destination 集合中去。
当 destination 集合已经包含 member 元素时, SMOVE 命令只是简单地将 source 集合中的 member 元素删除。
当 source 或 destination 不是集合类型时,返回一个错误。
返回:如果成员元素被成功移除,返回 1 。 如果成员元素不是 source 集合的成员,并且没有任何操作对 destination 集合执 行,那么返回 0 。
示例:sinter set1 set2
用法:返回给定所有给定集合的交集。 不存在的集合 key 被视为空集。 当给定集合当中有一个空集时,结果也为空集(根据集合运算定
返回:交集成员列表
示例:sismember set key
用法:判断成员元素是否是集合的成员。
返回:是成员返回1,不是成员或者key不存在返回0
示例:sdiffstore/sinter/sunion dest set1 set2
用法:将给定集合之间的差集/交集/并集存储在指定的集合中。如果指定的集合 key 已存在,则会被覆盖。
返回:差集/交集/并集成员列表
127.0.0.1:6379> sadd message open full paint key close switch 添加多个val
(integer) 6
127.0.0.1:6379> smembers message 列出所有的val
1) "paint"
2) "full"
3) "open"
4) "key"
5) "close"
6) "switch"
127.0.0.1:6379> sadd set1 a b c w e r
(integer) 6
127.0.0.1:6379> sadd set2 c w e r k l
(integer) 6
127.0.0.1:6379> sdiff set1 set2 差集
1) "b"
2) "a"
127.0.0.1:6379> sinter set1 set2 交集
1) "e"
2) "w"
3) "r"
4) "c"
127.0.0.1:6379> sunion set1 set2 并集
1) "b"
2) "e"
3) "a"
4) "k"
5) "w"
6) "r"
7) "l"
8) "c"
127.0.0.1:6379> sdiffstore diffset set1 set2 交集转储(并集、差集同理)
(integer) 2
127.0.0.1:6379> smembers diffset
1) "b"
2) "a"
127.0.0.1:6379>