Set
- 无序的
- Set 中的值只有一个(唯一性)
- 存储最多 2的32次方 -1 个字符串
集合类型的常用操作是向集合中加入或删除元素,判断某个元素是否存在,由于集合在Redis内部是使用值为空的散列表(hash table),所以这些操作时间复杂度都是 O(1) ,多个集合还可以进行并集、交集和差集运算
SADD 增加元素和 SREM 删除元素
- SADD key value1 [value2 value3 …] // 添加一个或者多个
SADD 向集合中增加一个或者读个元素,如果key 不存在自动创建,如果要加入的元素已经存在在集合中则会忽略该元素
127.0.0.1:6379[4]> SADD aa a1 a2 a3 a1
(integer) 3
127.0.0.1:6379[4]> SMEMBERS aa
1) "a2"
2) "a3"
3) "a1"
- SREM key value1 [value2 value3 …] // 删除一个或者多个
返回删除的个数
127.0.0.1:6379[4]> SMEMBERS aa
1) "a2"
2) "a3"
3) "a1"
127.0.0.1:6379[4]> SREM aa a1
(integer) 1
127.0.0.1:6379[4]> SMEMBERS aa
1) "a2"
2) "a3"
SMEMBERS 返回集合中所有的元素
SISMEMBER 判断集合中是否有该元素
SISMEMBER key value
返回值为 1 代表有,0 代表无
127.0.0.1:6379[4]> SMEMBERS aa
1) "a2"
2) "a3"
127.0.0.1:6379[4]> SISMEMBER aa a2
(integer) 1
127.0.0.1:6379[4]> SISMEMBER aa a1
(integer) 0
127.0.0.1:6379[4]>
集合运算
SDIFF key [k1 … ] 多个集合的差集运算
SINTER key [k1 … ] 多个集合的 交集运算
SUNION key [k1 … ] 多个集合的并集运算
SCARD 获得集合中元素的个数
SCARD key
进行集合运算并将结果存储
SDIFFSTORE destintion key [key …] 差集运算
SINTERSTORE destintion key [key …] 并集运算
SUNIONSTORE destintion key [key …] 交集运算
SRANDMEMBER 随机获取集合中的几个值
SRANDMEMBER key [count]
- count 参数随机获取count个元素
- count 为正数的时候, 会随机从集合中获取count个不重复的元素, 如果count 大于集合的元素个数,则返回集中的全部数据
- count 为负数的时候,会从集合中获取 |count| 个元素,且这些元素有可能相同
127.0.0.1:6379[4]> SMEMBERS aa
1) "a2"
2) "a3"
127.0.0.1:6379[4]> SRANDMEMBER aa
"a3"
127.0.0.1:6379[4]> SRANDMEMBER aa
"a2"
127.0.0.1:6379[4]> SRANDMEMBER aa 1
1) "a2"
127.0.0.1:6379[4]> SRANDMEMBER aa 1
1) "a3"
127.0.0.1:6379[4]>
127.0.0.1:6379[4]> SRANDMEMBER aa 2
1) "a2"
2) "a3"
127.0.0.1:6379[4]> SRANDMEMBER aa -2
1) "a2"
2) "a2"
SPOP 从集合中随机弹出一个元素或多个元素
SPOP key [count]
127.0.0.1:6379[4]> SPOP aa 2
1) "a2"
2) "a3"
127.0.0.1:6379[4]> SMEMBERS aa
(empty list or set)