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

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
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月前
|
NoSQL 安全 测试技术
Redis游戏积分排行榜项目中通义灵码的应用实战
Redis游戏积分排行榜项目中通义灵码的应用实战
81 4
|
2月前
set集合
HashSet(无序,唯一): 基于 HashMap 实现的,底层采用 HashMap 来保存元素。 LinkedHashSet: LinkedHashSet 是 HashSet 的子类,并且其内部是通过 LinkedHashMap 来实现的。 TreeSet(有序,唯一): 红黑树(自平衡的排序二叉树)。
|
2月前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
|
2月前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。
|
2月前
|
存储 NoSQL PHP
如何用Redis高效实现点赞功能?用Set?还是Bitmap?
在众多软件应用中,点赞功能几乎成为标配。本文从实际需求出发,探讨如何利用 Redis 的 `Set` 和 `Bitmap` 数据结构设计高效点赞系统,分析其优缺点,并提供 PHP 实现示例。通过对比两种方案,帮助开发者选择最适合的存储方式。
61 3
|
2月前
|
Java 开发者
从 Java 中的 Set 集合中删除元素
【10月更文挑战第30天】
|
2月前
|
存储 消息中间件 NoSQL
Redis数据结构:List类型全面解析
Redis数据结构——List类型全面解析:存储多个有序的字符串,列表中每个字符串成为元素 Eelement,最多可以存储 2^32-1 个元素。可对列表两端插入(push)和弹出(pop)、获取指定范围的元素列表等,常见命令。 底层数据结构:3.2版本之前,底层采用**压缩链表ZipList**和**双向链表LinkedList**;3.2版本之后,底层数据结构为**快速链表QuickList** 列表是一种比较灵活的数据结构,可以充当栈、队列、阻塞队列,在实际开发中有很多应用场景。
|
3月前
|
NoSQL 关系型数据库 MySQL
MySQL与Redis协同作战:优化百万数据查询的实战经验
【10月更文挑战第13天】 在处理大规模数据集时,传统的关系型数据库如MySQL可能会遇到性能瓶颈。为了提升数据处理的效率,我们可以结合使用MySQL和Redis,利用两者的优势来优化数据查询。本文将分享一次实战经验,探讨如何通过MySQL与Redis的协同工作来优化百万级数据统计。
154 5
|
3月前
|
存储 NoSQL 关系型数据库
Redis 有序集合(sorted set)
10月更文挑战第17天
154 4
|
2月前
|
存储 NoSQL 关系型数据库
Redis的ZSet底层数据结构,ZSet类型全面解析
Redis的ZSet底层数据结构,ZSet类型全面解析;应用场景、底层结构、常用命令;压缩列表ZipList、跳表SkipList;B+树与跳表对比,MySQL为什么使用B+树;ZSet为什么用跳表,而不是B+树、红黑树、二叉树