redis基础之集合类型

来源:互联网 发布:互联网公司算法 编辑:程序博客网 时间:2024/05/18 02:55

集合类型(set)和列表类型有相似之处,在集合中的每个元素都不同,且没有顺序。一个集合类型键可以存储至多2^32-1个字符串。

集合类型的常用操作室向集合中加入或者删除元素、判断某个元素是否在等,由于集合类型在Redis内部是使用值为空的散列表(hash table)实现的,所以这些操作的时间复杂度为O(1)。最方便的是多个集合键之间还可以进行并集、交集和差集运算。


增加和删除元素

SADD key member [member ...]
SREM key member [member ...]
SADD命令用来向集合中增加一个或者多个元素,如果键不存在则会自动创建。因为在一个集合中不能有相同的元素,所以如果要加入的元素已经存在于集合中就会忽略这个元素。本命令会返回成功加入元素数量(忽略的元素不计算在内)。SERM命令用来从集合中删除一个或者多个元素,并返回删除成功的个数。例如:
<pre name="code" class="plain">127.0.0.1:6379> SADD letters a(integer) 1127.0.0.1:6379> SADD letters a b c(integer) 2127.0.0.1:6379> SREM letters c d(integer) 1
第二条SADD命令返回值为2,因为元素“a”已经存在,而在SREM中,由于元素d在集合中不存在,所以只是返回了一个元素。

获得集合中所有元素

SMEMBERS key
SMEMBERS命令会返回集合中的所有元素,例如:
127.0.0.1:6379> SMEMBERS letters1) "a"2) "b"

判断元素是否在集合中

SISMEMBER key member
判断一个元素是否在集合中是一个时间复杂度为O(1)的操作,无论集合中有多少个元素,SISMEMBER命令始终可以快速地返回结果。
127.0.0.1:6379> SISMEMBER letters a(integer) 1127.0.0.1:6379> SISMEMBER letters d(integer) 0

集合运算

SDIFF  key [key ...]
SINTER key [key ...]
SUNION key [key ...]
1) SDIFF用来对多个集合执行差集运算。集合A和集合B的差集表示为A-B,代表所有属于A且不属于B的元素构成的集合。SDIFF命令支持同时传入多个键,例如:SDIFF setA setB setC表示先做setA和setB的差集,结果再和setC做差集。
2)SINTER命令用来对多个集合做交集运算。集合A和集合B的交集代表所有属于A且属于B的元素构成的集合。
3) SUNION命令用来对多个集合做并集。集合A和集合B的并集表示所有属于A或者属于B的元素构成的集合。

存储集合运算结果

SDIFFSTORE destination key [key ...]
SINTERSTORE destination key [key ...]
SUNIONSTORE destination key [key ...]
这三条命令和集合运算命令功能一样,唯一的区别在于前者不会直接返回运算结果,而是将结果存储于destination键中。

获取集合中元素个数

SCARD key

随机或缺集合中的元素

SRANDMEMBER key [count]
其中count默认为1,count参数用来一次取多个元素,根据count的正负不同,具体表现也不同。
1) 当count为正数时,SRANDMEMBER 会随机从集合中获得count个不重复的元素。如果count的值大于集合中的元素,则返回集合中全部的元素。
2) 当count为负数时,SRANDMEMBER会随机从集合中获得|count|个元素,这些元素可能相同。

从集合中弹出一个元素

SPOP key
SPOP命令会从集合中随机选择一个元素弹出。弹出的元素不会再出现在集合中。


0 0
原创粉丝点击