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
- redis基础之集合类型
- Redis从基础命令到实战之集合类型(Set)
- Redis之基础类型
- Redis之Set 集合类型
- Redis基础之有序集合
- Redis从基础命令到实战之有序集合类型(SortedSet)
- redis之集合类型(set)
- Redis快速入门之集合类型
- Redis之Sorted-sets 有序集合类型
- Redis数据类型之集合类型--Redis系列五
- Redis数据类型之有序集合类型--Redis系列六
- Redis基础之数据类型(Set无序集合)
- Redis基础之数据类型(SortedSet有序集合)
- redis基础之数据类型--散列类型
- redis基础之数据类型--列表类型
- [入门-4] 基础类型之集合
- c#基础之集合 类型总结
- redis集合类型
- SQL_逻辑运算符
- 关于进程和线程的区别
- hibernate继承关系映射
- IPhone之NSXMLParser的使用 (转)
- HDU 1181 变形课
- redis基础之集合类型
- 解决了一个ios真机上的内存越界问题
- 快速排序 Java
- 笔记:VIM随时随地做运算
- Lex与Yacc的使用
- ACM(1)
- Python抓取单个网页中所有的PDF文档
- 2014年,天猫双十一会达到怎么样的交易数据呢?
- ViewPage的监听类SimpleOnPageChangeListener