Redis研究(六)—集合类型

一、介绍

一个集合类型(set)键可以存储至多2^32-1个字符串。

Redis研究(六)—集合类型_第1张图片

集合类型在Redis内部是使用值为空的散列表(hash table)实现的,所以操作的复杂度为O(1)。多个集合类型键之间还可以进行并集、交集和差集运算。


二、命令

1.增加/删除元素

sadd key member
srem key member

sadd用来向集合中增加一个或者多个元素,如果键不存在则会自动创建。一个集合中不能有相同的元素,所以如果要加入的元素已经存在于集合中就会忽略这个元素。本命令的返回值是成功加入的元素数量。

Redis研究(六)—集合类型_第2张图片

第二条sadd命令返回2,因为a已经存在,实际上只加入两个元素。

srem用来从集合中删除一个或者多个元素,并返回删除成功的个数,

由于d在集合中不存在,所以只删除了一个元素,返回值为1.


2.获得集合中的所有元素

smembers key

返回集合所有元素

Redis研究(六)—集合类型_第3张图片


3.判断元素是否在集合中

sismember key member

时间复杂度O(1),无论有多少个元素。

Redis研究(六)—集合类型_第4张图片


4.集合之间运算

sdiff key
sinter key
sunion key

(1)sdiff差集运算,A-B,属于A但不属于B

Redis研究(六)—集合类型_第5张图片

sdiff支持同时传入多个键

Redis研究(六)—集合类型_第6张图片

顺序先计算setA-setB,再计算结果与setC的差集。

(2)sinter交集运算

Redis研究(六)—集合类型_第7张图片

sinter同样支持同时传入多个键。

(3)sunion并集运算。

Redis研究(六)—集合类型_第8张图片

sunion同样支持同时传入多个键。


三、命令拾遗

1.获得集合中元素个数


scard key
Redis研究(六)—集合类型_第9张图片

2.进行集合运算并将结果存储

sdiffstore destination key
sinterstore destination key
sunionstore destination key

和sdiff功能一样,唯一区别前者不会直接返回运算结果,而是将结果存储在destination键中。


3.随机获得集合中的元素

srandmember key [count]

Redis研究(六)—集合类型_第10张图片

count参数一次随机获得多个元素。

(1)count正数,获得count个不重复的元素,当大于集合元素个数,返回集合全部元素

(2)count负数,绝对值个元素,可能相同。


4.从集合中弹出一个元素

spop key

从集合中随机选择一个元素弹出。

Redis研究(六)—集合类型_第11张图片

你可能感兴趣的:(redis,集合,散列表,集合类型)