当前位置: 首页 > java >正文

Redis Set 类型详解:从基础命令到实战应用

前言

在 Redis 的众多数据结构中,Set(集合)是一种非常有特色的类型。它与列表(List)类似,都可以存储多个字符串元素,但 Set 具有两个核心特性:元素的无序性元素的唯一性

  • 无序性意味着 Set 中的元素没有先后顺序,{a, b, c} 和 {c, a, b} 被认为是同一个集合。

  • 唯一性确保了每个元素在集合中只会出现一次,这使得 Set 成为实现数据去重、统计独立访客(UV)等场景的天然选择。

本文将深入探讨 Redis Set 类型的常用操作命令,包括添加、删除、查询以及强大的交集、并集、差集运算,并结合实际应用场景,展示 Set 在开发中的妙用。

1、集合中的元素是无序的
list[1,2,3]和[2,3,1]是两个不用的list
set[1,2,3]和[2,3,1]是一个集合

2、集合中的元素是不能重复的(元素都是唯一的)
集合可以用来进行去重

和list类似,集合中的每个类型,也都是string类型
可以使用JSON这样的格式让string也能存储

sadd、smembers、sismember

sadd:将一个或者多个元素添加到set中,注意,重复的元素无法添加到set中的
这里的个体元素叫做member
时间复杂度是O(1)

sadd key member [member ...]

返回值就是本次操作成功添加了几个元素
image.png

不能重复添加一个数
image.png

smembers:获取一个set中的所有元素,注意,元素之间的顺序是无序的

smembers key

image.png

sismember:判断一个元素在不在set中,在的话就返回1,不在的话就返回了0
时间复杂度O(1)

sismember key member

image.png
image.png

spop、srandmember

正常的pop是删除末尾元素的,我们这里是因为是集合中,无序的,所以spop是随机删除的
spop:从set中删除并返回一个或者多个元素,注意,由于set内的元素是无序的,所以取出的元素是随机的

这里的count是要删除几个元素,不写的话就是默认删除一个元素,写的话就是删除count个元素

spop key [count]

image.png

srandmember是从指定的集合中返回一个或者多个元素

srandmember key [count]

image.png

smove、srem

smove将一个元素从一个集合中取出并且放到另一个集合中去

smove source destination member

返回值1表示移动成功,0表示移动失败

将member从source上删除,然后插入到destination中
image.png
如果需要进行移动的元素不存在的话会返回0的

srem:将制定的元素从set中删除

srem key member [member...]

可以删除一个member,也可以一次删除多个member
返回值表示删除元素的元素个数

sinter、sinterstore

交集(inster)、并集(union)、差集(diff)

交集:最终结果同时出现在两个集合中

并集:把多个集合中的数据集中放在一起,如果元素有重复,也最终只保留一份

差集:a和b作差集就是找出那些元素在a中存在,在b中不存在的

sinter:获取给指定的一个集合或者是多个集合的交集

时间复杂度是O(N* M) N是最小的集合的元素个数,M是最大的集合元素个数

sinter key [key ...]

返回值就是交集的元素
image.png

sinterstore :获取指定的set的交集的元素并且保存到目标的set中

直接将算好的交集,放到destination这个key对应的集合中

sinterstore destination key [key ...]

返回值就是交集的元素个数
要想知道交集的内容的话,我们直接按照访问集合的方式访问destination这个Key即可
image.png

sunion、sunionstore、sdiff、sdiffstore

sunion:获取指定的set的并集中的元素

sunion key [key...]

返回值是并集的元素
image.png

sunionstore:获取指定元素的并集并且放到destination中

sunionstore destination key [key...]

image.png

sdiff:获取指定set的差集中的元素

sdiff key [key...]

image.png

sdiffstore:将指定set的差集中的元素获取到destination中

sdiffstore destination key [key...]

image.png

命令总结

命令时间复杂度
sadd key element [element …]O(k), k 是元素个数
srem key element [element …]O(k), k 是元素个数
scard keyO(1)
sismember key elementO(1)
srandmember key [count]O(n), n 是 count
spop key [count]O(n), n 是 count
smembers keyO(k), k 是元素个数
sinter key [key …] sitnerstoreO(m * k), k 是几个集合中元素最小的个数, m 是键个数
sunion key [key …] sunionstoreO(k), k 是多个集合的元素个数总和
sdiff key [key …] sdiffstoreO(k), k 是多个集合的元素个数总和

内部编码方式

image.png

set应用场景

1、使用set来保存用户的标签

2、set方便计算交集,很容易得找到两个用户之间的公共标签
使用set来计算用户之间的共同好友

3、使用set统计UV
去重

总结

通过本文的学习,我们全面了解了 Redis 的 Set 数据类型。回顾一下关键知识点:

  1. 核心特性:Set 是一个无序且元素唯一的字符串集合。这一特性使其在需要去重和进行集合运算的场景中表现出色。

  2. 基本操作:我们掌握了 sadd 添加、srem 删除、smembers 查看所有成员、sismember 判断成员是否存在等基础命令,其中大部分操作都具有 O(1) 的高效时间复杂度。

  3. 集合运算:Set 最强大的功能之一是其高效的集合运算能力。通过 sinter (交集)、sunion (并集) 和 sdiff (差集) 命令,我们可以轻松实现复杂的数据分析和关联查询。

  4. 应用场景:我们探讨了 Set 在实际开发中的应用,例如存储用户标签、计算共同好友/兴趣、以及利用其唯一性进行网站 UV 统计等。这些场景充分发挥了 Set 的优势。

总而言之,Redis Set 以其简洁的数据模型和强大的运算能力,为处理许多常见业务问题提供了高效且优雅的解决方案。

http://www.xdnf.cn/news/18587.html

相关文章:

  • git实战(8)git高阶命令分析【结合使用场景】
  • 本地Docker部署开源Web相册图库Piwigo与在线远程访问实战方案
  • 如何优雅解决 OpenCV 分段错误(Segfault):子进程隔离实战
  • pig框架导入总结
  • 动手学深度学习(pytorch版):第六章节—卷积神经网络(1)从全连接层到卷积
  • 新能源汽车热管理仿真:蒙特卡洛助力神经网络训练
  • Text2SQL、ChatBI简介
  • [Vid-LLM] 功能分类体系 | 视频如何被“观看“ | LLM的主要作用
  • Flink2.0学习笔记:使用HikariCP 自定义sink实现数据库连接池化
  • 一键部署开源 Coze Studio
  • 第三阶段数据库-9:循环,编号,游标,分页
  • 字节跳动开源Seed-OSS:36B参数模型以512K上下文与可控思考预算重新定义AI实用主义
  • [激光原理与应用-320]:结构设计 - Solidworks - 软件工具UI组织的核心概念
  • 解决散点图绘制算法单一导致的数据异常问题
  • STM32窗口看门狗(WWDG)深度解析:精准守护嵌入式系统的实时性
  • python学习DAY49打卡
  • SHAP分析+KOA-RIME开普勒结合霜冰算法双重优化BP神经网络+9种映射方法+新数据预测!机器学习可解释分析!
  • 【升级版】从零到一训练一个 0.6B 的 MoE 大语言模型
  • 云原生俱乐部-k8s知识点归纳(8)
  • day40-tomcat
  • k8s之 Pod 资源管理与 QoS
  • Angular初学者入门第三课——工厂函数(精品)
  • 日志搜索系统前端页面(暂无后端功能)
  • webrtc弱网-SendSideBandwidthEstimation类源码分析与算法原理
  • 手机横屏适配方案
  • 20250823给荣品RD-RK3588开发板刷Rockchip原厂的Buildroot【linux-5.10】时调通AP6275P的WIFI【源码部分】
  • ArkTS 语言全方位解析:鸿蒙生态开发新选择
  • 【AI基础:神经网络】17、神经网络基石:从MP神经元到感知器全解析 - 原理、代码、异或困境与突破
  • 线程间Bug检测工具Canary
  • uniapp 页面跳转及字符串转义