一:Redis 集合(Set)

Redis的Set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。

Redis 中 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。

二:set常用操作

  1)sadd(name,values) name对应的集合中添加元素

  2)scard(name) 获取name对应的集合中元素个数

  3)sdiff(keys, *args)  在第一个name对应的集合中且不在其他name对应的集合的元素集合

  4)sdiffstore(dest, keys, *args) 获取第一个name对应的集合中且不在其他name对应的集合,再将其新加入到dest对应的集合中

  5)sinter(keys, *args) 获取多一个name对应集合的交集

  6)sinterstore(dest, keys, *args) 获取多一个name对应集合的并集,再讲其加入到dest对应的集合中

  7)sismember(name, value) 检查value是否是name对应的集合的成员

  8)smembers(name) 获取name对应的集合的所有成员

  9)smove(src, dst, value) 将某个成员从一个集合中移动到另外一个集合

  10)spop(name) 从集合的左侧(头部)移除一个成员,并将其返回

  11)srandmember(name, numbers) 从name对应的集合中随机获取 numbers 个元素

  12)srem(name, values) 在name对应的集合中删除某些值

  13)sunion(keys, *args)  获取多一个name对应的集合的并集

  14)sunionstore(dest,keys, *args) 获取多一个name对应的集合的并集,并将结果保存到dest对应的集合中

  15)sscan(name, cursor=0, match=None, count=None)

三:示例

[BEGIN] // ::
127.0.0.1:[]> select 选择会话窗口3
OK
127.0.0.1:[]> sadd n1 在集合中增加数据
(integer)
127.0.0.1:[]> sadd n1
(integer)
127.0.0.1:[]> sadd n1
(integer)
127.0.0.1:[]> sadd n1
(integer)
127.0.0.1:[]> SCARD n1 集合中有多少个元素
(integer)
127.0.0.1:[]> sadd n2
(integer)
127.0.0.1:[]> sadd n2
(integer)
127.0.0.1:[]> sadd n2
(integer)
127.0.0.1:[]> sadd n2
(integer)
127.0.0.1:[]> scard n2
(integer)
127.0.0.1:[]> sdiff n1 n2 两个集合的差集在n1中,不在n2中
) ""
) ""
127.0.0.1:[]> sdiff n3 n1 n2
(empty list or set)
127.0.0.1:[]> SDIFFSTORE n3 n1 n2 两个集合的差集在n1中,不在n2中并保存到n3中
(integer)
127.0.0.1:[]> SINTER n1 n2 交集在n1中,也在n2中
) ""
) ""
127.0.0.1:[]> SINTERSTORE n4 n1 n2 交集在n1中,也在n2中,并保存到n4中
(integer)
127.0.0.1:[]> SISMEMBER n1 判断元素在不在集合中
(integer)
127.0.0.1:[]> SMEMBERS n1 查看集合
) ""
) ""
) ""
) ""
127.0.0.1:[]> SMEMBERS n2
) ""
) ""
) ""
) ""
127.0.0.1:[]> SMEMBERS n3
) ""
) ""
127.0.0.1:[]> SMEMBERS n4
) ""
) ""
127.0.0.1:[]> smove n1 n2 把集合n1中元素1移动集合n2中
(integer)
127.0.0.1:[]> SMEMBERS n1
) ""
) ""
) ""
127.0.0.1:[]> SMEMBERS n2
) ""
) ""
) ""
) ""
) ""
127.0.0.1:[]> spop n1 从集合左边移出一个元素并还回
""
127.0.0.1:[]> SMEMBERS n1
) ""
) ""
127.0.0.1:[]> SRANDMEMBER n2 从集体中随即取2个
) ""
) ""
127.0.0.1:[]> SRANDMEMBER n2
) ""
) ""
127.0.0.1:[]> SRANDMEMBER n2
) ""
) ""
127.0.0.1:[]> SRANDMEMBER n2
) ""
) ""
127.0.0.1:[]> SREM n2 从集合中删除一个元素
(integer)
127.0.0.1:[]> SUNION n1 n2 两个集体并集
) ""
) ""
) ""
) ""
127.0.0.1:[]> SUNION n5 n1 n2 两个集体并集,并保存到n5中
) ""
) ""
) ""
) ""
127.0.0.1:[]> SMEMBERS n5
(empty list or set)
127.0.0.1:[]> SUNIONSTORE n5 n1 n2 两个集体并集,并保存到n5中
(integer)
127.0.0.1:[]> SSCAN n5 match
(error) ERR syntax error
127.0.0.1:[]> SSCAN n5 match
) ""
) ) "" [END] // ::

  

缓存数据库-redis数据类型和操作(set)的更多相关文章

  1. 缓存数据库-redis数据类型和操作(list)

    转: 狼来的日子里! 奋发博取 缓存数据库-redis数据类型和操作(list) 一:Redis 列表(List) Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素导列表的头部( ...

  2. 缓存数据库-redis数据类型和操作(string)

    Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合) 一:String(字符串) string是redis ...

  3. 缓存数据库-redis数据类型和操作(sorted set)

    一:Redis 有序集合(sorted set) Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员. 不同的是每个元素都会关联一个double类型的分数.redis正是 ...

  4. 缓存数据库-redis数据类型和操作(hash)

    一:Redis 哈希(Hash) Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象. Redis 中每个 hash 可以存储 232 - 1 ...

  5. 缓存数据库redis

    什么是Redis? Redis是一个TCP服务器,支持请求/响应协议. 在Redis中,请求通过以下步骤完成: 客户端向服务器发送查询,并从套接字读取,通常以阻塞的方式,用于服务器响应. 服务器处理命 ...

  6. Redis数据类型及其操作

    redis数据类型即操作 1. 字符串 set 设置字符串 格式: set key value 例子: set name kainhuck get 获取字符串的值 格式: get key 例子: ge ...

  7. 缓存数据库-redis介绍

    一:Redis 简介 Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. Redis 与其他 key - value 缓存产品有以下三个特点: Redis支持数据的 ...

  8. Redis数据类型和操作

    <"Java技术员"成长手册>,包含框架.存储.搜索.优化.分布式等必备知识,都收集在GitHub JavaEgg ,N线互联网开发必备技能兵器谱,欢迎指导 Redis ...

  9. 三个缓存数据库Redis、Memcache、MongoDB

    >>Memcached Memcached的优点:Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key.value的字节大小以及服务器硬件性能,日常环境 ...

随机推荐

  1. Bypass AV meterpreter免杀技巧

    0x01 meterpreter简介 MetasploitFramework是一个缓冲区溢出测试使用的辅助工具,也可以说是一个漏洞利用和测试平台,它集成了各种平台上常见的溢出漏洞和流行的shellco ...

  2. Spring MVC+Spring+Mybatis+MySQL(IDEA)入门框架搭建

    目录 Spring MVC+Spring+Mybatis+MySQL(IDEA)入门框架搭建 0.项目准备 1.数据持久层Mybatis+MySQL 1.1 MySQL数据准备 1.2 Mybatis ...

  3. Tcp协议三次握手四次挥手

    一.什么是TCP TCP(Transmission Control Protocol 传输控制协议)是一种面向连接(连接导向)的.可靠的. 基于IP的传输层协议.TCP在IP报文的协议号是6. 二.什 ...

  4. python学习(22) 访问数据库

    原文链接:http://www.limerence2017.com/2018/01/11/python22/ 本文介绍python如何使用数据库方面的知识. SQLite SQLite是一种嵌入式数据 ...

  5. QCon技术干货:个推基于Docker和Kubernetes的微服务实践

    2016年伊始,Docker无比兴盛,如今Kubernetes万人瞩目.在这个无比需要创新与速度的时代,由容器.微服务.DevOps构成的云原生席卷整个IT界.在近期举办的QCon全球软件开发大会上, ...

  6. UDP ------ UDP IPPROTO_UDPLITE 参数

    介绍 传统的 UDP 通信对整个报文进行校验 UDP-LITE 通信则可以设置校验的长度,适用于可以接受轻微的报文内容出错,比如视频数据:传统的 UDP 由于对整个报文校验,一旦出现报文数据出错就会被 ...

  7. python 获取本机 IP

    原文 通过 UDP 获取本机 IP,目前见过最优雅的方法 这个方法是目前见过最优雅获取本机服务器的IP方法了.没有任何的依赖,也没有去猜测机器上的网络设备信息. 而且是利用 UDP 协议来实现的,生成 ...

  8. addEventListener() 事件监听

    addEventListener() 用于向指定元素添加事件. 可以向一个元素添加多次事件或者多次不同事件,后面的事件是不会覆盖前面的. 语法: element.addEventListener(ev ...

  9. 视音频数据处理入门:UDP-RTP协议解析

    ===================================================== 视音频数据处理入门系列文章: 视音频数据处理入门:RGB.YUV像素数据处理 视音频数据处理 ...

  10. 邮件中的CC和BCC含义

    CC 英文全称是 Carbon Copy(抄送);BCC英文全称是 Blind CarbonCopy(暗抄送). 两者的区别在于在BCC栏中的收件人可以看到所有的收件人名(TO,CC,BCC),而在T ...