一. 集合对象概述

  这里的集合是string类型的无序集合,在集合对象中集合成员是唯一的,这就意味着集合中不能出现重复的数据。集合是通过哈希表实现的,集合中最大的成员数为 232-1 (4294967295, 每个集合可存储40多亿个成员)。集合对象的编码可以是intset或者hashtable。

  1.1 intset编码

    intset编码的集合对象使用整数集合作为底层实现,集合对象包含的所有元素都被保存在整数集合里面。例如下面使用整数集合:

     127.0.0.1:> sadd numbers
(integer)
127.0.0.1:> object encoding numbers
"intset"

  1.2 hashtable编码

     另一个编码是hashtable,集合对象使用字典作为底层实现,字典的每个键都是一个字符串对象,每个字符串对象包含了一个集合元素,而字典的值则全部被设置为null。

    127.0.0.1:> sadd furits "apple" "banana"
(integer)
127.0.0.1:> object encoding furits
"hashtable"

  两个底层结构如下图所示,作为字典结构,键都是一个字符串对象,值都为NULL。

  1.3  编码转换

    当集合对象可以同时满足以下两个条件时,对象使用intset编码:(1) 集合对象保存的所有元素都是整数值;(2) 集合对象保存的元素数量不超过512个。当不能满足这两个条件的集合对象使用的是hashtable编码。对于第二个条件的上限值可以通过配置文件中的set-max-intset-entries选项来修改。

   127.0.0.1:6379> config get set-max-intset-entries
1) "set-max-intset-entries"
2) "512"

  

二. 集合命令实现

-- Sadd 命令将一个或多个成员元素加入到集合中,已经存在于集合的成员元素将被忽略。
127.0.0.1:> sadd myset "hello" "foo"
(integer) -- Scard 命令返回集合中元素的数量
127.0.0.1:> scard myset
(integer) -- Sdiff 命令返回给定集合之间的差集, 返回包含差集成员的列表。下面是返回myset1对比myset2,返回myset1的差集。
127.0.0.1:> sadd myset1 "hello" "foo" "bar"
(integer)
127.0.0.1:> sadd myset2 "hello" "world"
(integer)
127.0.0.1:> sdiff myset1 myset2
) "foo"
) "bar" -- Sdiffstore 命令将差集存储在指定的集合中,如果指定的集合(destination) key已存在,则会被覆盖, 下面集合key为 destset不存在,创建该新集合并且新集合值为二个集合的差集。

127.0.0.1:> sdiffstore destset myset1 myset2
(integer)
127.0.0.1:> smembers destset
) "foo"
) "bar" -- Sinter 命令返回给定所有给定集合的交集,与Sdiff相反。下面返回myset1和myset2二个集合共同有的值。
127.0.0.1:> sinter myset1 myset2
) "hello" -- Sinterstore命令将给定集合之间的交集存储在指定的集合中。如果指定的集合已经存在,则将其覆盖, 与Sdiffstore 相反。下面集合key为 destset2不存在,创建该新集合并且新集合值为二个集合的交集。 127.0.0.1:> sinterstore destest2 myset1 myset2
(integer)
127.0.0.1:> smembers destest2
) "hello" -- Sismember 命令判断成员元素是否是集合的成员。如果成员元素是集合的成员,返回 。
127.0.0.1:> sismember myset1 "hello"
(integer) -- Smembers 命令返回集合中的所有的成员。 不存在的集合 key 被视为空集合。
127.0.0.1:> smembers myset1
) "hello"
) "bar"
) "foo" -- Smove 命令将指定成员 member 元素从 source 集合移动到 destination 集合,SMOVE 是原子性操作。
127.0.0.1:> smembers myset1
) "hello"
) "bar"
) "foo"
127.0.0.1:> smembers myset2
) "hello"
) "world"
127.0.0.1:> smove myset1 myset2 "bar" --将myset1的元素移到myset2中
(integer)
127.0.0.1:> smembers myset1 -- myset1中少了"bar"元素
) "hello"
) "foo"
127.0.0.1:> smembers myset2 --myset2 中多了"bar" 元素
) "hello"
) "world"
) "bar" --Spop 命令用于随机移除指定count元素数量,并返回集合中的移出的元素。
127.0.0.1:> smembers myset1
) "three"
) "one"
) "hello"
) "two"
127.0.0.1:> spop myset1 --随机移除3个
) "hello"
) "two"
) "three"
127.0.0.1:> smembers myset1 --只剩下一个元素
) "one" --Srem 命令用于移除集合中的一个或多个成员元素,不存在的成员元素会被忽略。
127.0.0.1:> smembers myset1
) "three"
) "one"
) "two"
127.0.0.1:> srem myset1 "one" --移除指定元素
(integer)
127.0.0.1:> smembers myset1 --只剩下二个元素
) "three"
) "two" --Sunion 命令返回给定集合的并集,相当于sql中的join合并去重。
127.0.0.1:> smembers myset2
) "one"
) "two"
127.0.0.1:> smembers myset1
) "three"
) "two"
127.0.0.1:> sunion myset2 myset1 --返回合并后的元素
) "three"
) "one"
) "two" -- Sunionstore 命令将给定集合的并集,存储在指定的集合 destination 中。
127.0.0.1:> sunionstore myset myset2 myset1
(integer)
127.0.0.1:> smembers myset --并集后,存储到了myset集合中
) "three"
) "one"
) "two -- Sscan 命令用于迭代集合键中的元素
127.0.0.1:> smembers myset
) "three"
) "one"
) "two"
127.0.0.1:> sscan myset match t*
) ""
) ) "three"
) "two"

  

redis 系列13 集合对象的更多相关文章

  1. redis 系列15 数据对象的(类型检查,内存回收,对象共享)和数据库切换

    一.  概述 对于前面的五章中,已清楚了数据对象的类型以及命令实现,其实还有一种数据对象为HyperLogLog,以后需要用到再了解.下面再了解类型检查,内存回收,对象共享,对象的空转时长. 1.1 ...

  2. redis 系列10 字符串对象

    一. 字符串对象编码 Redis中字符串可以存储3种类型,分别是字节串(byte string).整数.浮点数.在上章节中讲到字符串对象的编码可以是int, raw,embstr. 如果一个字符串对象 ...

  3. redis 系列11 列表对象

    一. 列表对象概述 Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素到列表的头部(左边)或者尾部(右边).一个列表最多可以包含 232 - 1 个元素 (4294967295, ...

  4. 【目录】redis 系列篇

    随笔分类 - redis 系列篇 redis 系列27 Cluster高可用 (2) 摘要: 一. ASK错误 集群上篇最后讲到,对于重新分片由redis-trib负责执行,关于该工具以后再介绍.在进 ...

  5. redis 系列14 有序集合对象

    一. 有序集合概述 Redis 有序集合对象和集合对象一样也是string类型元素的集合,且不允许重复的成员.不同的是每个元素都会关联一个double类型的分数.redis正是通过分数来为集合中的成员 ...

  6. redis 系列9 对象类型(字符串,哈希,列表,集合,有序集合)与数据结构关系

    一.概述 在前面章节中,主要了解了 Redis用到的主要数据结构,包括:简单动态字符串.链表(双端链表).字典.跳跃表. 整数集合.压缩列表(后面再了解).Redis没有直接使用这些数据结构来实现键值 ...

  7. Java 集合系列 13 WeakHashMap

    java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...

  8. 从Redis中删除大集合对象的方法

    Redis中的大集合对象,如set.zset等,如果有上千万个元素,一般是不能直接用del命令来删除的,因为del命令可能会耗时几秒钟,而redis本身是单线程的,在高并发的情况下会阻塞大量的请求,严 ...

  9. redis是如何存储对象和集合的

    在项目中,缓存以及mq消息队列可以说是不可或缺的2个重要技术.前者主要是为了减轻数据库压力,大幅度提升性能.后者主要是为了提高用户的体验度,我理解的是再后端做的一个ajax请求(异步),并且像ribb ...

随机推荐

  1. Eclipse 那些小技巧(值得收藏)

    1.菜单命令系列 Edit→content Assist→add Alt+/ 代码关联 Windows→Next Editor→add Ctrl+Tab 切换窗口 Run→Debug Toggle L ...

  2. 【Linux】如何在Linux上安装使用SSH

    SSH是什么? Secure Shell 安全外壳协议 建立在应用层基础上的安全协议 可靠,专为远程登录会话和其他网络服务提供安全性的协议 有效防止远程管理过程中的信息泄露问题 SSH客户端适用于多种 ...

  3. Burnside引理和Polya定理之间的联系

    最近,研究了两天的Burnside引理和Polya定理之间的联系,百思不得其解,然后直到遇到下面的问题: 对颜色限制的染色 例:对正五边形的三个顶点着红色,对其余的两个顶点着蓝色,问有多少种非等价的着 ...

  4. VScode加文件头的方式

    在VScode中添加文件头,设置文件编辑者的方式,在软件中查询到file-header插件: 安装好,此时通过是可以生成默认的文件头.如果需要修改配置,在文件=>首选项=>设置中修改: 查 ...

  5. iOS报错:linker command failed with exit code 1 (use -v to see invocation) 问题解决方式之一

    百度库原版本:3.2.1  更新为:4.2.0,两个库相隔2年时间: 问题i: 更新CocoaPods的同时更新了百度地图库的版本,运行程序报错: linker command failed with ...

  6. Linux虚拟机搭建本地yum源

    Yum本地源的配置 本教程是在虚拟机里安装Red Hat Enterprise Linux 7 ,以其为例使用iso文件进行Yum本地源的配置.所使用的软件如下: (1)虚拟机:Vmware work ...

  7. Python-模块,以及使用文本中的数据

    模块导入: from math import pi as math_pi print math_pi     #相当于把pi取了个别名 # -*- coding: cp936 -*-from rand ...

  8. [BZOJ1925][SDOI2010]地精部落(DP)

    题意 传说很久以前,大地上居住着一种神秘的生物:地精. 地精喜欢住在连绵不绝的山脉中.具体地说,一座长度为 N 的山脉 H可分 为从左到右的 N 段,每段有一个独一无二的高度 Hi,其中Hi是1到N ...

  9. 论python中的函数参数的传递问题。

    python是完全面向对象的语言,在参数传递的过程不能使用值传递,引用传递的概念,而应该使用immutable和mutable.在java中,除了object,其实还有8种基本数据类型,才有了参数传递 ...

  10. 巧用PHP中__get()魔术方法

    PHP中的魔术方法有很多,这些魔术方法可以让PHP脚本在某些特定的情况下自动调用.比如 __construct() 每次实例化一个类都会先调用该方法进行初始化.这里我们讲一下__get() 魔术方法的 ...