一、集合(Set)简介

  1. Set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
  2. Redis 中 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
  3. 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

二、常用命令

1、sadd sadd <key><value1><value2> 将一个或多个 member 元素加入到集合 key 中,已经存在的 member 元素将被忽略
127.0.0.1:6379> keys *
(empty array)
127.0.0.1:6379> sadd myset a b c d #往myset集合了添加值
(integer) 4 #返回4
127.0.0.1:6379> sadd myset a b c d #往myset集合了添加重复值
(integer) 0 #返回0
127.0.0.1:6379>
2、smembers smembers <key>取出该集合的所有值。
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset #取出myset集合中所有的值
1) "c"
2) "d"
3) "b"
4) "a"
127.0.0.1:6379>
3、sismember sismember <key><value>判断集合是否为含有该值,有1,没有0
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset #查看当前集合中所有的值
1) "c"
2) "d"
3) "b"
4) "a"
127.0.0.1:6379> sismember myset d #判断当前集合是否存在d,存在返回1
(integer) 1
127.0.0.1:6379> sismember myset h #判断当前集合是否存在h,不存在返回0
(integer) 0
127.0.0.1:6379>
4、scard scard <key>返回该集合的元素个数。
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset #查看当前集合元素个数
1) "c"
2) "d"
3) "b"
4) "a"
127.0.0.1:6379> scard myset
(integer) 4
5、srem srem <key><value1><value2> .... 删除集合中的某个元素。
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset
1) "c"
2) "d"
3) "b"
4) "a"
127.0.0.1:6379> srem myset b #移除集合中存在的值
(integer) 1
127.0.0.1:6379> srem myset h #移除集合中不存在的值。返回0
(integer) 0
127.0.0.1:6379>
6、spop spop <key> 随机从该集合中吐出一个值。
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379> spop myset 1 #在当前集合随机弹出一个值
1) "c"
127.0.0.1:6379> spop myset 2 #再当前集合随机弹出两个值
1) "a"
2) "b"
127.0.0.1:6379> smembers myset #查看当前集合剩余的值
1) "d"
7、srandmember srandmember <key><n>随机从该集合中取出n个值。不会从集合中删除 。
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379> srandmember myset 2 #随机在集合中去取出2个值
1) "b"
2) "a"
127.0.0.1:6379> smembers myset #查看值是否被删除
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379>
8、smove smove <source> <destination> value把集合中一个值从一个集合移动到另一个集合
127.0.0.1:6379> sadd source a b c d					#在source里添加值
(integer) 4
127.0.0.1:6379> sadd destination 1 2 3 4 #在目标destination添加值
(integer) 4
127.0.0.1:6379> smembers source
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379> smembers destination
1) "1"
2) "2"
3) "3"
4) "4"
127.0.0.1:6379> smove source destination a #将source里面的a移动到destination集合里
(integer) 1
127.0.0.1:6379> smembers source #查看source集合
1) "d"
2) "c"
3) "b"
127.0.0.1:6379> smembers destination #查看destination集合里的元素
1) "4"
2) "3"
3) "2"
4) "1"
5) "a"
127.0.0.1:6379>
9、sinter sinter <key1><key2>返回两个集合的交集元素。
127.0.0.1:6379> sadd k1 1 2 3 a b c
(integer) 6
127.0.0.1:6379> sadd k2 a b c 4 5 6
(integer) 6
127.0.0.1:6379> smembers k1
1) "a"
2) "1"
3) "3"
4) "c"
5) "b"
6) "2"
127.0.0.1:6379> smembers k2
1) "4"
2) "b"
3) "a"
4) "6"
5) "c"
6) "5"
127.0.0.1:6379> sinter k1 k2 #返回两个集合公共的元素
1) "a"
2) "c"
3) "b"
10、sunion sunion <key1><key2>返回两个集合的并集元素。
127.0.0.1:6379> sadd k1 1 2 3 a b c
(integer) 6
127.0.0.1:6379> sadd k2 a b c 4 5 6
(integer) 6
127.0.0.1:6379> smembers k1
1) "a"
2) "1"
3) "3"
4) "c"
5) "b"
6) "2"
127.0.0.1:6379> smembers k2
1) "4"
2) "b"
3) "a"
4) "6"
5) "c"
6) "5"
127.0.0.1:6379> sunion k1 k2 #k1与k2的并集
1) "c"
2) "4"
3) "b"
4) "2"
5) "a"
6) "1"
7) "6"
8) "5"
9) "3"
11、 sdiff sdiff <key1><key2>返回两个集合的差集元素(key1中的,不包含key2中的)
127.0.0.1:6379> sadd k1 1 2 3 a b c
(integer) 6
127.0.0.1:6379> sadd k2 a b c 4 5 6
(integer) 6
127.0.0.1:6379> smembers k1
1) "a"
2) "1"
3) "3"
4) "c"
5) "b"
6) "2"
127.0.0.1:6379> smembers k2
1) "4"
2) "b"
3) "a"
4) "6"
5) "c"
6) "5"
127.0.0.1:6379> sdiff k1 k2 #返回k1集合与k2集合的差集(用k1集合减去k1与k2的交集)
1) "1"
2) "2"
3) "3"

三、总结

  1. Redis 的集合相当于 Java 语言里面的 HashSet,它内部的键值对是无序的唯一的。它的内部实现相当于一个特殊的字典,字典中所有的 value 都是一个值 NULL。
  2. 当集合中最后一个元素移除之后,数据结构自动删除,内存被回收。set 结构可以用来存储活动中奖的用户 ID,因为有去重功能,可以保证同一个用户不会中奖两次。
  3. set有交集、并集和补集,可以实现好友像好友推荐功能。
  4. list集合不具有唯一性,set是不重复的,保证唯一性。

7、Redis五大数据类型---集合(Set)的更多相关文章

  1. Redis五大数据类型的常用操作

    在上一篇博文<centos安装redis>中,已经详细介绍了如何在centos上安装redis,今天主要介绍下Redis五大数据类型及其五大数据类型的相关操作. Redis支持五种数据类型 ...

  2. 一文搞定Redis五大数据类型及应用场景

    本文学习知识点 redis五大数据类型数据类型:string.hash.list.set.sorted_set 五大类型各自的应用场景 @TOC 1. string类型 1-1 string类型数据的 ...

  3. redis 五大数据类型使用

    redis 五大数据类型使用 字符串str 单个值 127.0.0.1:6379> set name pp # 设置键值[O(1)] OK 127.0.0.1:6379> setex na ...

  4. 《Redis入门指南(第二版)》读书思考总结之Redis五大数据类型

    热身:系统级命令 1. 获得符合规则的键名列表 KEYS pattern 模式匹配 产品的缓存:product+"."+....;  => keys product* 订单的 ...

  5. Redis五大数据类型详解

    关于Redis的五大数据类型,它们分别为:String.List.Hash.Set.SortSet.本文将会从它的底层数据结构.常用操作命令.一些特点和实际应用这几个方面进行解析.对于数据结构的解析, ...

  6. redis五大数据类型以及常用操作命令

    Redis的五大数据类型 String(字符串) string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value.string类型是二进制安全的.意 ...

  7. 四:Redis五大数据类型

    Redis的五大数据类型 1.string(字符串) string是Redis最基本的类型,你可以理解成与menmcached一模一样的类型,一个key对应一个value string类型是二进制安全 ...

  8. 细谈Redis五大数据类型

    文章原创于公众号:程序猿周先森.本平台不定时更新,喜欢我的文章,欢迎关注我的微信公众号. 上一篇文章有提到,Redis中使用最频繁的有5种数据类型:String.List.Hash.Set.SortS ...

  9. Redis五大数据类型以及操作

    目录: 一.redis的两种链接方式 二.redis的字符串操作(string) 三.redis的列表操作(list) 四.redis的散列表操作(类似于字典里面嵌套字典) 五.redis的集合操作( ...

随机推荐

  1. asp.net中HttpCookie操作cookie的方法

    微软对HttpCookie的定义为"提供创建和操作各 HTTP Cookie 的类型安全方法." HttpCookie的构造函数一共有两个 1.HttpCookie(String) ...

  2. Typora图片自动上传至码云

    Typora图片自动上传至码云 下载PicGo图片上传工具 PicGo下载地址 下载完毕后打开PicGo,点击插件设置,搜索Gitee,点击安装gitee 2.0.3 码云仓库创建 创建参数是点击设置 ...

  3. webRTC中语音降噪模块ANS细节详解(四)

    上篇(webRTC中语音降噪模块ANS细节详解(三))讲了噪声的初始估计方法以及怎么算先验SNR和后验SNR. 本篇开始讲基于带噪语音和特征的语音和噪声的概率计算方法和噪声估计更新以及基于维纳滤波的降 ...

  4. .NET Protobuf包装器库

    Wodsoft Protobuf Wrapper 内容 关于 需求 安装 用法 序列化 反序列化 字段定义 字段排序 非空构造函数对象 获取Protobuf包装器 高级 支持的属性类型与Protobu ...

  5. 面向对象中static的理解(2) (单例模式)

    作用:只产生一个对象 1 class Yoshi { 2 public: 3 //外界只能通过这种方式调用这一个对象,返回必须是引用 4 static Yoshi& getInstance() ...

  6. Apache Kafka分布式流处理平台及大厂面试宝典v3.0.0

    概述 **本人博客网站 **IT小神 www.itxiaoshen.com 定义 Apache Kafka官网地址 http://kafka.apache.org/ 最新版本为 3.0.0 Apach ...

  7. [Cnoi2020]线性生物

    期望入门题.但是我不会做. 考虑设\(E_{x\to{x+1}}\)为\(x\)到\(x+1\)点的期望步数. 则\(ans = \sum_{i = 0}^{n} E_{x\to{x+1}}\) 知\ ...

  8. 洛谷 P4088 [USACO18FEB] Slingshot P(线段树+二维数点)

    题目链接 题意:有一个数轴,上面有 \(n\) 个传送门,使用第 \(i\) 个传送门,你可以从 \(x_i\) 走到 \(y_i\),花费的时间为 \(t_i\) 秒.你的速度为 \(1\) 格/秒 ...

  9. 使用FastqCount统计fastq文件基本信息?

    目录 1. FastqCount简介 2. 使用 3. 结果 1. FastqCount简介 快速实用小工具:FastqCount https://github.com/zhimenggan/Fast ...

  10. Linux图片查看软件ImageMagick安装

    在Linux中查看图片,这个需求是非常常见的.总不至于在集群中生成个图片,随便看下效果,也要用filezilla.winscp之类的远程文件传输工具导过来导过去吧,这样效率太低. Linux图片查看常 ...