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

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.dtcms.com/a/346624.html

相关文章:

  • OpenJDK 17 安全点检查机制深入解析
  • 【AI基础:神经网络】16、神经网络的生理学根基:从人脑结构到AI架构,揭秘道法自然的智能密码
  • Photoshop CS6精简版轻量级,Photoshop CS6绿色免安装,Photoshop CS6安装教程
  • Kafka 概念与概述
  • AI热点周报(8.17~8.23):Pixel 10“AI周”、DeepSeek V3.1发布,英伟达再起波澜?
  • Kafka Streams vs Apache Flink vs Apache Storm: 实时流处理方案对比与选型建议
  • 何为‘口业’,怎么看待它
  • 轻量化设计·全要素监测——新一代便携式气象站赋能户外科研与应急
  • Elasticsearch Persistence(elasticsearch-persistence)仓储模式实战
  • 改华为智能插座为mqtt本地控制
  • 强光干扰与密集场景下工服识别准确率↑89%!陌讯多模态融合算法在安全生产中的实战优化
  • 华为/思科/H3C/锐捷操作系统操作指南
  • Mybatis面试题分享
  • 【网安干货】--操作系统基础(上)
  • 深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)第五章整理
  • Python爬虫实战:研究WSL技术,构建跨平台数据采集和分析系统
  • 攻防世界—Confusion1—(模板注入ssti)
  • IPsec
  • selenium采集数据怎么应对反爬机制?
  • C++算法·进制转换
  • 2025/8/23c++++++++
  • kafaka知识要点
  • Spring Boot 3为何强制要求Java 17?
  • 【modbus】数据采集系统
  • 微服务概述1
  • Elasticsearch Ruby 客户端 Bulk Scroll Helpers 实战指南
  • 【Redis 进阶】----主从复制(重点理解流程和原理)
  • 【Tech Arch】Apache Flume海量日志采集的高速公路
  • 如何在 Spring Boot 中安全读取账号密码等
  • SpringBoot3整合dubbo3客户端【最佳实践】