Redis学习-Set
在Redis中,Set类型是没有排序的字符集合,和List类型一样,可以在该类型的数据值上执行添加、删除或判断某一元素是否存在等操作。需要说明的是,这些操作的时间复杂度为O(1),即常量时间内完成次操作。Set可包含的最大元素数量是4294967295。和List类型不同的是,Set集合中不允许出现重复的元素。换句话说,如果多次添加相同元素,Set中将仅保留该元素的一份拷贝。和List类型相比,Set类型在功能上还存在着一个非常重要的特性,即在服务器端完成多个Sets之间的聚合计算操作,如unions、intersections和differences。由于这些操作均在服务端完成,因此效率极高,而且也节省了大量的网络IO开销。
基本操作
|
命令 |
描述 |
复杂度 |
返回值 |
|
SADD key [member ...] |
将一个或多个member元素加入到集合 key 当中,已经存在于集合的member元素将被忽略。假如key不存在,则创建一个只包含 member元素作成员的集合。当key不是集合类型时,返回一个错误。 |
O(N), N 是被添加的元素的数量。 |
被添加到集合中的新元素的数量,不包括被忽略的元素。 |
|
SCARD key |
返回集合 key 的基数(集合中元素的数量)。 |
O(1) |
集合的基数。key不存在时,返回 0 。 |
|
SDIFF key [key ...] |
返回一个集合的全部成员,该集合是所有给定集合之间的差集。不存在的key被视为空集。 |
O(N),N是所有集合的成员数量之和。 |
一个包含差集成员的列表。 |
|
SDIFFSTORE destination key [key ...] |
作用和SDIFF类似,但它将结果保存到 destination.而不是简单地返回结果集.如果destination集合已经存在,则将其覆盖。destination可以是key本身。 |
O(N),N 是所有给定集合的成员数量之和。 |
结果集中的元素数量。 |
|
SINTER key [key ...] |
返回一个集合的全部成员,该集合是所有给定集合的交集。不存在的key被视为空集。当给定集合当中有一个空集时,结果也为空集 |
O(N * M), N 为给定集合当中基数最小的集合, M 为给定集合的个数。 |
交集成员的列表。 |
|
SINTERSTORE destination key [key ...] |
类似SINTER命令,但它将结果保存到destination 集合,而不是简单地返回结果集。如果destination 集合已经存在,则将其覆盖。destination可以是 key本身。 |
O(N * M), N 为给定集合当中基数最小的集合, M 为给定集合的个数。 |
结果集中的成员数量。 |
|
SISMEMBER key member |
判断 member 元素是否集合 key 的成员。 |
O(1) |
是1 ;不是或 key不存在返回0 。 |
|
SMEMBERS key |
返回集合 key 中的所有成员。不存在的 key 被视为空集合。 |
O(N), N为集合的基数。 |
集合中的所有成员。 |
|
SMOVE source destination member |
将member元素从source移动到destination.SMOVE 是原子性操作。如果source不存在或不包含指定的member元素,则SMOVE命令不执行任何操作,仅返回0 。否则, member元素从 source 集合中被移除,并添加到 destination 集合中去。当 destination 集合已经包含 member 元素时, SMOVE命令只是简单地将 source 集合中的 member 元素删除。当 source或 destination 不是集合类型时,返回一个错误。 |
O(1) |
如果member元素被成功移除,返回 1 。如果 member元素不是source 集合的成员,并且没有任何操作对 destination集合执行,那么返回 0 。 |
|
SPOP key |
移除并返回集合中的一个随机元素。如果只想获取一个随机元素,但不想该元素从集合中被移除的话,可以使用 SRANDMEMBER 命令。 |
O(1) |
被移除的随机元素。当 key不存在或key是空集时,返回nil 。 |
|
SREM key member [member ...] |
移除集合 key中的一个或多个 member元素,不存在的 member元素会被忽略。当key不是集合类型,返回一个错误。 |
O(N), N 为给定 member 元素的数量。 |
被成功移除的元素的数量,不包括被忽略的元素。 |
|
SUNION key [key ...] |
返回一个集合的全部成员,该集合是所有给定集合的并集。不存在的 key 被视为空集。 |
O(N), N是所有集合的成员数量之和。 |
O(N), N 是所有给定集合的成员数量之和。 |
|
SUNIONSTORE destination key [key ...] |
类似于 SUNION 命令,但它将结果保存到 destination集合,而不是简单地返回结果集。 |
O(N), N 是所有给定集合的成员数量之和。 |
结果集中的元素数量。 |
应用范围
- 可以使用Redis的Set数据类型跟踪一些唯一性数据,比如访问某一博客的唯一IP地址信息。对于此场景,我们仅需在每次访问该博客时将访问者的IP存入Redis中,Set数据类型会自动保证IP地址的唯一性。
- 充分利用Set类型的服务端聚合操作方便、高效的特性,可以用于维护数据对象之间的关联关系。比如所有购买某一电子设备的客户ID被存储在一个指定的Set中,而购买另外一种电子产品的客户ID被存储在另外一个Set中,如果此时我们想获取有哪些客户同时购买了这两种商品时,Set的intersections命令就可以充分发挥它的方便和效率的优势了。
Redis学习-Set的更多相关文章
- Redis学习手册(目录)
为什么自己当初要选择Redis作为数据存储解决方案中的一员呢?现在能想到的原因主要有三.其一,Redis不仅性能高效,而且完全免费.其二,是基于C/C++开发的服务器,这里应该有一定的感情因素吧.最后 ...
- redis 学习笔记(6)-cluster集群搭建
上次写redis的学习笔记还是2014年,一转眼已经快2年过去了,在段时间里,redis最大的变化之一就是cluster功能的正式发布,以前要搞redis集群,得借助一致性hash来自己搞shardi ...
- Redis——学习之路四(初识主从配置)
首先我们配置一台master服务器,两台slave服务器.master服务器配置就是默认配置 端口为6379,添加就一个密码CeshiPassword,然后启动master服务器. 两台slave服务 ...
- Redis——学习之路三(初识redis config配置)
我们先看看config 默认情况下系统是怎么配置的.在命令行中输入 config get *(如图) 默认情况下有61配置信息,每一个命令占两行,第一行为配置名称信息,第二行为配置的具体信息. ...
- Redis——学习之路二(初识redis服务器命令)
上一章我们已经知道了如果启动redis服务器,现在我们来学习一下,以及如何用客户端连接服务器.接下来我们来学习一下查看操作服务器的命令. 服务器命令: 1.info——当前redis服务器信息 s ...
- Redis学习笔记~目录
回到占占推荐博客索引 百度百科 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合). ...
- Redis学习笔记4-Redis配置详解
在Redis中直接启动redis-server服务时, 采用的是默认的配置文件.采用redis-server xxx.conf 这样的方式可以按照指定的配置文件来运行Redis服务.按照本Redi ...
- Redis学习笔记1-Redis的介绍和认识
说明:文章内容来自百度百科和redis官方对redis的介绍 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API ...
- Redis学习笔记7--Redis管道(pipeline)
redis是一个cs模式的tcp server,使用和http类似的请求响应协议.一个client可以通过一个socket连接发起多个请求命令.每个请求命令发出后client通常会阻塞并等待redis ...
- 分布式缓存技术redis学习系列(五)——redis实战(redis与spring整合,分布式锁实现)
本文是redis学习系列的第五篇,点击下面链接可回看系列文章 <redis简介以及linux上的安装> <详细讲解redis数据结构(内存模型)以及常用命令> <redi ...
随机推荐
- 读书笔记 effective c++ Item 38 通过组合(composition)为 “has-a”或者“is-implemented-in-terms-of”建模
1. 什么是组合(composition)? 组合(composition)是一种类型之间的关系,这种关系当一种类型的对象包含另外一种类型的对象时就会产生.举个例子: class Address { ...
- Kubernetes使用cephfs作为后端存储
这里使用了k8s自身的持久化卷存储机制:PV和PVC.各组件之间的关系参考下图: PV的Access Mode(访问模式) The access modes are: ReadWriteOnce – ...
- Oracle子查询中any、some、all之间的区别
用some,any和all对子查询中返回的多行结果进行处理. 下面我们来简单介一下这几个关键词的含义. * Some在此表示满足其中一个的意义,是用or串起来的比较从句. * Any也表示满足其中一个 ...
- js原生的轮播图
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <t ...
- VB中的GDI编程-1 设备环境DC
p{ font-size: 15px; } .alexrootdiv>div{ background: #eeeeee; border: 1px solid #aaa; width: 99%; ...
- Xmpp实现简单聊天系列 --- ②用户注册和登陆
不管是注册还是登陆,亦或是聊天等功能,都必须先进行服务器连接,连接代码如下 ①自定义Xmpp连接工具类: ②调用创建连接的方法: ③连接服务器方法: *注意 连接方式为客服 ...
- 6.Java集合总结系列:常见集合类的使用(List/Set/Map)
MARK 总结: Set.List 和 Map 可以看做集合的三大类. List集合是有序集合,集合中的元素可以重复,访问集合中的元素可以根据元素的索引来访问. Set集合是无序集合,集合中的元素不可 ...
- 高性能MySQL--索引学习笔记(原创)
看过一些人写的学习笔记,完全按书一字不漏照抄,内容很多,真不能叫笔记.遂自己整理了一份,取其精要. 更多笔记请访问@个人简书 [toc] 索引概述 索引即key 在存储引擎层实现,不同引擎工作方式不同 ...
- js 计时器小练-20160601
今天要做一个计时器小练,所以我就做了练习,代码如下. // 初始化时间,以及定义全局量去接收计时器 var timer = 0; var t; var h, min, sec, millisec; / ...
- ios sqlite3的简单使用
第一:创建表格 //创建表格 -(void)creatTab{ NSString*creatSQL=@"CREATE TABLE IF NOT EXISTS PERSIONFO(ID INT ...