【Redis实战】集合类型(Set)

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis的集合类型

1、增加/删除元素(SADD和SREM)

  SADD命令用来向集合中增加一个或多个元素,如果键不存在则会自动创建。该命令的返回值是成功加入的元素数量。

127.0.0.1:6379> SADD letters a
(integer) 1
127.0.0.1:6379> SADD letters a b c
(integer) 2

  第二条SADD命令的返回值为2是因为元素“a”已经存在,所以实际上只加入了两个元素。

127.0.0.1:6379> SREM letters c d
(integer) 1

  SREM命令用来从集合中删除一个或多个元素,并返回删除成功的个数。由值于元素“d”在集合中不存在,所有只删除了一个元素,返回值为1。

2、获得集合中得到所有元素(SMEMBERS)

  SMEMBERS命令会返回集合中的所有元素。

127.0.0.1:6379> SMEMBERS letters
1) "b"
2) "a"

3、判断元素是否在集合中(SISMEMBER)

  当值存在时,SISMEMBER命令返回1,否则返回0。

127.0.0.1:6379> SISMEMBER letters a
(integer) 1
127.0.0.1:6379> SISMEMBER letters d
(integer) 0

4、集合间运算(SDIFF/SINTER/SUNION)

(1)SDIFF命令用来对多个集合执行差集运算。

127.0.0.1:6379> SADD setA 1 2 3
(integer) 3
127.0.0.1:6379> SADD setB 2 3 4
(integer) 3
127.0.0.1:6379> SDIFF setA setB
1) "1"
127.0.0.1:6379> SDIFF setB setA
1) "4"

  SDIFF命令支持同时传入多个件,例如:计算顺序是先计算setA-setB,再计算结果与setC的差集。

127.0.0.1:6379> SADD setC 2 3
(integer) 2
127.0.0.1:6379> SDIFF setA setB setC
1) "1"

(2)SINTER命令用来对多个集合执行交集运算。

127.0.0.1:6379> SINTER setA setB
1) "2"
2) "3"

  SINTER命令同样支持同时传入多个键,如:

127.0.0.1:6379> SINTER setA setB setC
1) "2"
2) "3"

(3)SUNION命令用来对多个集合执行并集运算。

127.0.0.1:6379> SUNION setA setB
1) "1"
2) "2"
3) "3"
4) "4"

  SUNION命令同时支持传入多个键,例如:

127.0.0.1:6379> SUNION setA setB setC
1) "1"
2) "2"
3) "3"
4) "4"

5、获得集合中元素个数(SCARD)

  SCARD命令用来获得集合中的元素个数。

127.0.0.1:6379> SMEMBERS letters
1) "b"
2) "a"
127.0.0.1:6379> SCARD letters
(integer) 2

6、进行集合运算并将结果存储(SDIFFSTORE)

  SDIFFSTORE命令和SDIFF命令功能一样,唯一的区别就是前者不会直接返回运算结果,而是将结果存储在destination键中。
  SDIFFSTORE命令常用于需要多步集合运算的场景中,如需要先计算差集再将结果和其他键计算交集。

7、随机获得集合中的元素(SRANDMEMBER)

  SRANDMEMBER命令用来随机从集合中获取一个元素。

127.0.0.1:6379> SRANDMEMBER letters
"a"
127.0.0.1:6379> SRANDMEMBER letters
"b"

  还可以传递count参数来一次随机获得多个元素,根据count的正负不同,具体表现也不同。
  (1)当count为正数时,SRANDMEMBER会随机从集合里获得count个不重复的元素。如果count的值大于集合中的元素个数,则SRANDMEMBER会返回集合中的全部元素。
  (2)当count为负数时,SRANDMEMBER会随机从集合里获得|count|个的元素,这些元素有可能相同。

127.0.0.1:6379> SMEMBERS letters
1) "b"
2) "c"
3) "a"
4) "d"
127.0.0.1:6379> SRANDMEMBER letters 2
1) "b"
2) "d"
127.0.0.1:6379> SRANDMEMBER letters 2
1) "b"
2) "a"
127.0.0.1:6379> SRANDMEMBER letters 100
1) "b"
2) "a"
3) "c"
4) "d"
127.0.0.1:6379> SRANDMEMBER letters -2
1) "b"
2) "c"
127.0.0.1:6379> SRANDMEMBER letters -10
 1) "a"
 2) "b"
 3) "d"
 4) "d"
 5) "d"
 6) "a"
 7) "d"
 8) "a"
 9) "d"
10) "c"

8、从集合中弹出一个元素(SPOP)

  SPOP命令会从集合中随机选择一个元素弹出。

127.0.0.1:6379> SPOP letters
"c"
127.0.0.1:6379> SMEMBERS letters
1) "b"
2) "a"
3) "d"
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
2天前
|
消息中间件 存储 负载均衡
Redis类型 Stream Bitfield
Redis类型 Stream Bitfield
9 0
|
2天前
|
SQL NoSQL Java
Redis数据类型 Hash Set Zset Bitmap HyperLogLog GEO
Redis数据类型 Hash Set Zset Bitmap HyperLogLog GEO
12 0
|
8天前
|
监控 NoSQL 算法
探秘Redis分布式锁:实战与注意事项
本文介绍了Redis分区容错中的分布式锁概念,包括利用Watch实现乐观锁和使用setnx防止库存超卖。乐观锁通过Watch命令监控键值变化,在事务中执行修改,若键值被改变则事务失败。Java代码示例展示了具体实现。setnx命令用于库存操作,确保无超卖,通过设置锁并检查库存来更新。文章还讨论了分布式锁存在的问题,如客户端阻塞、时钟漂移和单点故障,并提出了RedLock算法来提高可靠性。Redisson作为生产环境的分布式锁实现,提供了可重入锁、读写锁等高级功能。最后,文章对比了Redis、Zookeeper和etcd的分布式锁特性。
108 16
探秘Redis分布式锁:实战与注意事项
|
11天前
|
存储 NoSQL Java
Spring Boot与Redis:整合与实战
【4月更文挑战第29天】Redis,作为一个高性能的键值存储数据库,广泛应用于缓存、消息队列、会话存储等多种场景中。在Spring Boot应用中整合Redis可以显著提高数据处理的效率和应用的响应速度。
26 0
|
14天前
|
存储 缓存 NoSQL
node实战——koa给邮件发送验证码并缓存到redis服务(node后端储备知识)
node实战——koa给邮件发送验证码并缓存到redis服务(node后端储备知识)
19 0
|
15天前
|
存储 NoSQL Redis
Redis入门到通关之Redis数据结构-Set篇
Redis入门到通关之Redis数据结构-Set篇
20 1
|
15天前
|
存储 缓存 NoSQL
Redis入门到通关之Redis缓存数据实战
Redis入门到通关之Redis缓存数据实战
21 0
|
15天前
|
存储 NoSQL Redis
Redis入门到通关之Set实现点赞功能
Redis入门到通关之Set实现点赞功能
15 0
|
15天前
|
存储 缓存 NoSQL
Redis入门到通关之Set命令
Redis入门到通关之Set命令
18 0
|
16天前
|
存储 缓存 NoSQL
Redis 命令全解析之 Hash类型
Redis 命令全解析之 Hash类型
12 1