Redis的Set操作

集合的性质: 唯一性,无序性,确定性

注: 在string和link的命令中,可以通过range 来访问string中的某几个字符或某几个元素

但,因为集合的无序性,无法通过下标或范围来访问部分元素.

因此想看元素,要么随机先一个,要么全选

sadd key value1 value2
作用: 往集合key中增加元素
127.0.0.1:6379> sadd gender male female
(integer) 2
127.0.0.1:6379> sadd gender yao yao
(integer) 1
127.0.0.1:6379> sadd gender yao
(integer) 0
smembers key
作用: 返回集中中所有的元素
127.0.0.1:6379> smembers gender
1) "male"
2) "female"
3) "yao"
srem value1 value2
作用: 删除集合中集为 value1 value2的元素
返回值: 忽略不存在的元素后,真正删除掉的元素的个数
127.0.0.1:6379> srem gender yao
(integer) 1
127.0.0.1:6379> srem gender x c
(integer) 0
127.0.0.1:6379> srem gender male x c
(integer) 1
spop key//抽奖
作用: 返回并删除集合中key中1个随机元素
随机--体现了无序性
127.0.0.1:6379> sadd gender a b c d e f
(integer) 6
127.0.0.1:6379> smembers gender
1) "d"
2) "c"
3) "a"
4) "f"
5) "female"
6) "b"
7) "e"
127.0.0.1:6379> spop gender
"a"
127.0.0.1:6379> smembers gender
1) "d"
2) "c"
3) "f"
4) "female"
5) "b"
6) "e"
127.0.0.1:6379> spop gender
"c"
127.0.0.1:6379> spop gender
"f"
127.0.0.1:6379> spop gender
"e"
srandmember key
作用: 返回集合key中,随机的1个元素.
127.0.0.1:6379> smembers gender
1) "d"
2) "c"
3) "a"
4) "f"
5) "female"
6) "e"
7) "b"
127.0.0.1:6379> srandmember gender
"female"
127.0.0.1:6379> srandmember gender
"f"
127.0.0.1:6379> srandmember gender
"c"
127.0.0.1:6379> srandmember gender
"c"
127.0.0.1:6379> srandmember gender
"a"
127.0.0.1:6379> srandmember gender
"d"
sismember key  value
作用: 判断value是否在key集合中
是返回1,否返回0
127.0.0.1:6379> smembers gender
1) "d"
2) "c"
3) "a"
4) "f"
5) "female"
6) "e"
7) "b"
127.0.0.1:6379> sismember gender q
(integer) 0
127.0.0.1:6379> sismember gender f
(integer) 1
scard key
作用: 返回集合中元素的个数127.0.0.1:6379> scard gender(integer) 7
smove source dest value
作用:把source中的value删除,并添加到dest集合中
127.0.0.1:6379> sadd upper A B C
(integer) 3
127.0.0.1:6379> sadd lower a b c
(integer) 3
127.0.0.1:6379> smove upper lower A
(integer) 1
127.0.0.1:6379> smembers upper
1) "C"
2) "B"
127.0.0.1:6379> smembers lower
1) "c"
2) "A"
3) "b"
4) "a"
sinter  key1 key2 key3
作用: 求出key1 key2 key3 三个集合中的交集,并返回
sinterstore dest key1 key2 key3
作用: 求出key1 key2 key3 三个集合中的交集,并赋给dest
suion key1 key2.. Keyn
作用: 求出key1 key2 keyn的并集,并返回
127.0.0.1:6379> sadd lisi a b c d
(integer) 4
127.0.0.1:6379> sadd wang a c d e f
(integer) 5
127.0.0.1:6379> sadd poly a c d g
(integer) 4
127.0.0.1:6379> sinter lisi wang poly
1) "d"
2) "c"
3) "a"
127.0.0.1:6379> sinterstore common lisi wang poly
(integer) 3
127.0.0.1:6379> smembers common
1) "d"
2) "c"
3) "a"
127.0.0.1:6379> sunion lisi wang poly
1) "d"
2) "g"
3) "c"
4) "a"
5) "f"
6) "e"
7) "b"
sdiff key1 key2 key3
作用: 求出key1与key2 key3的差集
即key1-key2-key3
127.0.0.1:6379> sdiff lisi wang poly
1) "b"
时间: 2024-12-22 23:18:17

Redis的Set操作的相关文章

redis的hash操作在集中式session中的应用

在集群部署时,为了高可用性的目的,往往把session进行共享,共享分为两种:session复制和集中式管理. redis在session集中式管理中可以起到比较大的作用. 制约session集中式共享的两大因素: 1. session必须有ha机制,集群中部分服务器发生故障时,保证session不丢失. 2. session的生命周期管理. 3. session的大小未知,整体的序列化和反序列化成本比较高. redis的解决方式 1. redis具有持久化功能,且sentiment具有ha功效

Redis的相关操作

参考文献:http://www.runoob.com/redis/redis-transactions.html redis下载(Windows安装)D:\downloads\redis>redis-server.exe redis.windows.conf(启动服务)打开另一个cmd终端:D:\downloads\redis>redis-cli(打开本地连接)D:\downloads\redis>redis-cli.exe -h 127.0.0.1 -p 6379(打开远程连接,然后打

redis集群介绍、redis集群搭建配置、redis集群操作

一:redis集群介绍 多个redis节点网络互联,数据共享所有的节点都是一主一从(可以是多个从),其中从不提供服务,仅作为备用不支持同时处理多个键(如mset/mget),因为redis需要把键均匀分布在各个节点上,并发量很高的情况下同时创建键值会降低性能并导致不可预测的行为.支持在线增加.删除节点客户端可以连任何一个主节点进行读写 二:redis集群搭建配置 场景设置:两台机器,分别开启三个Redis服务(端口)A机器上三个端口7000,7002,7004,全部为主B机器上三个端口7001,

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

转: 狼来的日子里! 奋发博取 缓存数据库-redis数据类型和操作(list) 一:Redis 列表(List) Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素导列表的头部(左边)或者尾部(右边) 一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素). List操作,redis中的List在在内存中按照一个name对应一个List来存储.如图: 二:列表常用操作 1)lpush(name,values)  在name对应的l

Redis 以及 Python操作Redis

Redis Redis是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. Redis有以下特点: -- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用. -- Redis支持五种数据类型. -- Redis支持数据库备份. Redis的优势: -- Redis性能极高,读的速度是110000次/s,写的速度是81000次/s. -- Redis丰富的数据类型,String,Lists,Hashes,Sets以及Ordered S

redis之常见操作

目录 redis的常见操作 1. redis客户端登录方式 2. 设置密码 3. 获取redis的配置 4. redis键(key) 语法 实例 Redis keys (黄色为重点) redis的常见操作 1. redis客户端登录方式 本地使用redis客户端登录 redis-cli 远程服务器上使用客户端登录 # 格式 redis-cli -h host -p port -a password 2. 设置密码 在配置文件中配置密码(即使重启服务也能有效) # 编辑redis的配置文件 red

redis的常用操作

redis的介绍: redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorted set --有序集合)和hash(哈希类型).这些数据类型都支持push/pop.add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的.在此基础上,redis支持各种不同方式的排序.与memcached一样,为了保证效率,数据都是缓存在内存中.区别的是redis

学习记录04 --- 使用java连接redis数据库进行操作

现在先简单的尝试下java如何连接上redis数据库 首先我们需要一个jedis.jar架包,我下载的是2.9.0的版本 附上下载地址,点击我下载 开始我们的常规操作,打开idea,导入架包,emmmmm,感觉这次会写的特别简短 先导包 import redis.clients.jedis.Jedis; 我们需要连接redis数据库的话,都是依赖于jedis对象而来的,我们先得new出一个jedis对象 //new一个Jedis对象,连接redis数据库 Jedis jedis = new Je

使用 redis (基础, key操作, string类型操作)

使用redis set 类型: 没有重复元素 list 链表类型 有重复累型 sort set 类型 没有重复元素 1.1 存储数据 读取数据 // 数据储存在 内存中 set name laowen // OK 表示成功 set age 22    // ok 表示成功 set add beijing // OK 表示成功 get name // "laowen" 表示获取成功 get age // "22" 表示获取成功 get addr // "be

C#Redis 常用key操作

一.前戏 在该系列的前几篇博客中,主要讲述的是与Redis数据类型相关的命令,如String.List.Set.Hashes和Sorted-Set.这些命令都具有一个共同点,即所有的操作都是针对与Key关联的Value的.而该篇博客将主要讲述与Key相关的Redis命令.学习这些命令对于学习Redis是非常重要的基础,也是能够充分挖掘Redis潜力的利器.      在该篇博客中,我们将一如既往的给出所有相关命令的明细列表和典型示例,以便于我们现在的学习和今后的查阅. 二.理论 命令原型 时间复