一、Redis之Set简介

1. Set是String类型的无序集合(元素成员唯一)。

2. Set是通过hash表实现的,添加、删除、查找的复杂度都是O(1)。

3. 每个集合最大成员数为232-1(40多亿)个。

二、Redis之Set命令行操作

Sadd:将一个或多个元素加入集合,已经存在集合中的元素则忽略。若集合不存在则先创建,若key不是集合类型则返回错误。

Smembers:返回集合中所有成员。

Scard:返回集合中元素的数量。

Spop:移除并返回集合中的一个或多个随机元素。(count不能为负数)

Srandmember:返回集合中的一个或多个随机成员元素,返回元素的数量和情况由命令中的count参数决定:

1. 如果count为正数,且小于集合基数,那么命令返回一个包含count个元素的数组,数组中的元素各不相同。

2. 如果count大于等于集合基数,那么返回整个集合。

3. 如果count为负数,那么命令返回一个数组,数组中的元素可能会重复出现多次,而数组的长度为count的绝对值。

Srandmember和Spop相似,但Spop将随机元素从集合中移除并返回,而Srandmember则仅仅返回随机元素,而不对集合进行任何改动。

Srem:移除集合中指定的一个或多个元素,忽略不存在的元素。

Sscan:迭代集合中的元素。

Smove:将指定成员从一个源集合移动到一个目的集合。相当于两个操作,将指定元素从源集合中删除,并加入目的集合中。若源集合不存在或不包含指定元素则不做任何操作。

下面介绍的差集、交集和并集都将使用以下三个集合来示例:

Sdiff:返回所有给定集合之间的差集,不存在的集合视为空集。

Sdiffstore:将所有给定集合之间的差集存储在指定的目的集合中。若目的集合已存在则覆盖它。

差集:第一个集合中有,其他集合没有的元素。

Sinter:返回所有给定集合的交集,不存在的集合视为空集。

Sinterstore:将所有给定集合的交集存储在指定的目的集合中。若目的集合已存在则覆盖它。

Sunion:返回所有给定集合的并集,不存在的集合视为空集。

Sunionstore:将所有给定集合的并集存储在指定的目的集合中。若目的集合已存在则覆盖它。

最新文章

  1. apache自带的web监控器配置
  2. Leetcode Construct Binary Tree from Inorder and Postorder Traversal
  3. 高效的INSERT INTO SELECT和SELECT INTO
  4. 第九篇 :微信公众平台开发实战Java版之如何实现自定义分享内容
  5. Git连接Github
  6. django框架的网站发布后设置是否允许被别人iframe引用
  7. Myeclipse2014 SVN安装方法以及项目上传到svn服务器
  8. 文本编辑工具vim
  9. Typescript---03 类、接口、枚举
  10. python实现将字符串中以大写字母开头的单词前面添加“_”下划线
  11. java_29打印流
  12. MySQL设置空密码
  13. String的疑问
  14. Zip伪加密 破解ZIP密码
  15. Android Studio 遇到 No Debuggable Applications 的解决方案
  16. hdu1114 dp(完全背包)
  17. Linux下ssh的使用
  18. c# datarow[] 转换成 datatable, List<T> 转datatable
  19. 解决Max retries exceeded with url的问题
  20. CRF,没完全看懂

热门文章

  1. Java数据结构和算法(五)--希尔排序和快速排序
  2. Oracle数据库同步方案
  3. python 删除大表数据
  4. springboot的启动类不能直接放在src/java目录下,不然会报错
  5. 常用JS方法整理
  6. 【git】不检查特定文件的更改情况
  7. Python9-集合-day7
  8. uboot-imx RGB24分析
  9. LeetCode(112) Path Sum
  10. 《C/C++工程师综合练习卷》之小试牛刀