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

【Redis】深入探索 Redis 的数据类型 —— 无序集合 Set

文章目录

  • 一、Set 类型介绍
  • 二、Set 类型相关命令
    • 2.1 添加元素和检查成员
    • 2.2 移除元素
    • 2.3 集合运算
      • 求交集
      • 求并集
      • 求差集
    • 2.4 Set 相关命令总结
  • 三、Set 类型编码方式
  • 四、Set 使用场景


一、Set 类型介绍

Set(集合)是 Redis 数据库中的一种数据类型,它是一种无序的、不重复的数据结构,用于存储一组唯一的元素。Set 在 Redis 中非常实用,因为它提供了高效的成员查找和去重功能,常用于处理一些需要存储唯一值的场景。以下是关于 Redis 中 Set 类型的介绍:

特点和用途:

  1. 无序性:Set 中的元素是无序排列的,与元素的插入顺序无关。

  2. 唯一性:Set 中的元素是唯一的,不允许出现重复元素。

  3. 高效的成员查找:Redis 提供了高效的成员查找操作,可以快速判断一个元素是否存在于集合中。

  4. 去重:由于元素的唯一性,Set 常用于去重操作,将一组数据转换为不含重复元素的数据集。

  5. 集合运算:Redis 提供了多个集合运算命令,可以对多个集合进行交集、并集和差集等操作。

  6. 支持多种数据类型:Set 可以存储字符串、数字、甚至其他 Redis 数据类型的元素。

二、Set 类型相关命令

Set(集合)是 Redis 中的一种无序且不重复的数据结构,它包含了一组唯一的成员。以下是与 Set 数据类型相关的常见命令:

2.1 添加元素和检查成员

  1. SADD:将一个或多个成员添加到集合中。

    语法:

    SADD key member [member ...]
    
  2. SMEMBERS:返回集合中的所有成员。

  3. SISMEMBER:检查指定成员是否存在于集合中。

    语法:

    SISMEMBER key member
    
  4. SCARD:获取集合的基数(即成员数量)。

    语法:

    SCARD key
    

2.2 移除元素

  1. SPOP:随机移除并返回集合中的一个成员。

    语法:

    SPOP key [count]
    
  2. SMOVE:将指定成员从一个集合移动到另一个集合。

    语法:

    SMOVE source destination member
    
  3. SREM:从集合中移除一个或多个成员。

    语法:

    SREM key member [member ...]
    

2.3 集合运算

求交集

  1. SINTER:返回多个集合的交集。

    语法:

    SINTER key [key ...]
    
  2. SINTERSTORE:将多个集合的交集存储到一个新集合中。

    语法:

    SINTERSTORE destination key [key ...]
    

求并集

  1. SUNION:返回多个集合的并集。

    语法:

    SUNION key [key ...]
    
  2. SUNIONSTORE:将多个集合的并集存储到一个新集合中。

    语法:

    SUNIONSTORE destination key [key ...]
    

求差集

  1. SDIFF:返回第一个集合与其他集合的差集。

    语法:

    SDIFF key [key ...]
    
  2. SDIFFSTORE:将第一个集合与其他集合的差集存储到一个新集合中。

    语法:

    SDIFFSTORE destination key [key ...]
    

2.4 Set 相关命令总结

以下是与 Set 类型相关的命令的总结,包括命令、作用和时间复杂度:

命令作用时间复杂度
SADD向集合中添加一个或多个成员O(N) (N 为添加成员的数量)
SMEMBERS返回集合中的所有成员O(N) (N 为集合中的元素数量)
SISMEMBER检查成员是否存在于集合中O(1)
SCARD获取集合的基数(成员数量)O(1)
SPOP随机移除并返回集合中的一个成员O(1)
SMOVE将成员从一个集合移动到另一个集合O(1)
SREM从集合中移除一个或多个成员O(N) (N 为移除成员的数量)
SINTER返回多个集合的交集O(N*M) (N 和 M 为集合的大小)
SINTERSTORE将多个集合的交集存储到一个新集合中O(N*M) (N 和 M 为集合的大小)
SUNION返回多个集合的并集O(N+M) (N 和 M 为集合的大小)
SUNIONSTORE将多个集合的并集存储到一个新集合中O(N+M) (N 和 M 为集合的大小)
SDIFF返回第一个集合与其他集合的差集O(N) (N 为第一个集合的大小)
SDIFFSTORE将第一个集合与其他集合的差集存储到一个新集合中O(N) (N 为第一个集合的大小)

Set 数据类型适用于需要存储一组唯一值的情况,例如标签、用户的兴趣爱好等。使用合适的 Set 相关命令,可以高效地进行成员的添加、删除、查找以及集合运算。

三、Set 类型编码方式

Redis 中的 Set 数据类型的内部编码方式有两种,分别是intsethashtable。这两种编码方式根据集合的大小和元素类型来选择,以最大程度地节省内存和提高性能。

  1. intset(整数集合)

    • 特点:intset 是 Redis 用于表示只包含整数值的集合的编码方式。它是一个有序的、紧凑的、不可重复的集合,内部使用整数表示元素值。

    • 适用场景:intset 适用于存储小型整数集合,因为它在内存占用和性能方面都非常高效。当集合中的元素都是整数且数量较少时,Redis 会选择使用 intset 编码。

    • 优点

      • 节省内存:intset 采用紧凑的二进制存储,每个整数只占用所需的字节。
      • 高效的查找和插入:由于元素都是整数且有序,查找和插入操作的时间复杂度是 O(log(N))。
  2. hashtable(哈希表)

    • 特点:hashtable 是 Redis 用于表示包含字符串、浮点数或其他数据类型的集合的编码方式。它是一个无序的、动态大小的集合,内部使用哈希表来存储元素。

    • 适用场景:hashtable 适用于存储包含各种数据类型的集合,以及大型集合,因为它可以动态增长并处理各种数据类型。

    • 优点

      • 适用性广泛:hashtable 可以存储不同类型的数据,而不仅限于整数。
      • 动态增长:可以随时添加或删除元素,适用于大型集合。

Redis 在使用 Set 类型时会根据集合的内容和大小自动选择 intset 或 hashtable 编码方式,以优化内存和性能。这种智能的编码方式选择是 Redis 内存管理的一部分,使得 Redis 在处理不同类型和大小的集合时能够充分发挥其优势。

四、Set 使用场景

场景:标签管理

假设你正在开发一个社交平台,需要为用户添加兴趣标签,并能够计算用户之间的共同兴趣标签。以下是如何使用 Redis 的集合数据类型来实现这个场景:

  1. 给用户添加标签

    用户A对娱乐、体育板块感兴趣,用户B对历史、新闻感兴趣,这些兴趣点可以被抽象为标签。

    SADD user:1:tags entertainment sports
    SADD user:2:tags history news
    

    这些命令将用户的标签信息存储在名为 user:1:tagsuser:2:tags 的集合中。

  2. 给标签添加用户

    现在,让我们为每个标签创建一个集合,用于存储对该标签感兴趣的用户。

    SADD entertainment:users user:1
    SADD sports:users user:1
    SADD history:users user:2
    SADD news:users user:2
    

    这些命令将用户与其对应的标签建立关联关系。

  3. 删除用户下的标签

    如果用户取消了对某些标签的兴趣,可以使用 SREM 命令来删除相应的标签。

    SREM user:1:tags sports
    

    这个命令将用户A的兴趣标签中的 “sports” 删除。

  4. 删除标签下的用户

    如果某个标签不再被用户关注,可以使用 SREM 命令来删除相应的用户。

    SREM sports:users user:1
    

    这个命令将用户A从 “sports” 标签的关注列表中移除。

  5. 计算用户的共同兴趣标签

    要计算两个用户的共同兴趣标签,可以使用 SINTER 命令。

    SINTER user:1:tags user:2:tags
    

    这个命令将返回用户1和用户2的共同兴趣标签。

通过这些 Redis 的集合操作,你可以轻松地实现标签管理功能,包括用户的兴趣标签添加、删除以及计算用户之间的共同兴趣标签。这对于增强用户体验和个性化推荐非常有帮助。

除了标签管理之外,Redis 的集合数据类型还适用于许多其他场景。以下是一些额外的场景示例:

  1. 社交网络关系:在社交网络应用中,你可以使用集合存储用户的好友列表、关注列表和粉丝列表,以及用户之间的共同好友等信息。这使得查找和管理社交关系变得非常高效。

  2. 在线用户管理:集合可以用于维护在线用户列表,快速检查用户是否在线,以及获取在线用户的数量和列表。这对于实时聊天、在线游戏等应用非常有用。

  3. 投票和计数:你可以使用集合来记录投票或计数的情况,例如统计文章的点赞数、收藏数、评论数等。每个用户可以在集合中表示一次投票或计数操作,而集合会自动去重。

相关文章:

【Redis】深入探索 Redis 的数据类型 —— 无序集合 Set

文章目录 一、Set 类型介绍二、Set 类型相关命令2.1 添加元素和检查成员2.2 移除元素2.3 集合运算求交集求并集求差集 2.4 Set 相关命令总结 三、Set 类型编码方式四、Set 使用场景 一、Set 类型介绍 Set(集合)是 Redis 数据库中的一种数据类型&#xf…...

可变参数JAVA

public class Main {public static void main(String[] args) {//方法形参的个数是可以变化的//格式:属性类型...名字System.out.println(getSum(1,2,3,4,5,6,7,8));}//通过键值对对象来遍历;public static int getSum(int a,int...args){//可变参数;int…...

Zabbix监控平台部署流程

Zabbix WEB、Zabbix Server、Zabbix Database放在一台服务器;(192.168.10.12)Zabbix Agent部署在被监控服务器上 (192.168.10.11)Zabbix Porxy 单独部署在一台服务器上(被监控服务器少于500台可以不部署&am…...

重磅!文晔以38亿美元收购富昌电子 | 百能云芯

文晔微电子股份有限公司(文晔科技)于9月14日正式宣布已完成对富昌电子公司(Future Electronics Inc.)100%股权的收购,该交易以全现金方式完成,总交易价值高达38亿美元。 文晔科技的董事长兼首席执行官郑家强…...

Multimodel Image synthesis and editing:The generative AI Era

1.introduction 基于GAN和扩散模型,通过融入多模态引导来调节生成过程,从不同的多模态信号中合成图像;是为多模态图像合成和编辑使用预训练模型,通过在GAN潜在空间中进行反演,应用引导函数,或调整扩散模型…...

Linux——(第十章)进程管理

目录 一、概述 二、常用指令 1.ps查看当前系统进程状态 2.kill 终止进程 3.pstree 查看进程树 4.top 实时监控系统进程状态 5.netstat 监控网络状态 一、概述 (1)进程是正在执行的一个程序或命令,每一个进程都是一个运行的实体&#…...

【操作系统】聊聊协程为什么可以支撑高并发服务

在实际的业务开发中,比如针对一个业务流程,调用三方,然后存储数据,从oss上获取数据。其实都是进行的同步调用,说白了就是A完成之后,B在继续完成。如果整个过程中A、B、C 分别耗时100、300、200毫秒。那么整…...

算法leetcode|80. 删除有序数组中的重复项 II(rust重拳出击)

文章目录 80. 删除有序数组中的重复项 II:样例 1:样例 2:提示: 分析:题解:rust:go:c:python:java: 80. 删除有序数组中的重复项 II: …...

Vite 完整版详解

1. 打包构建: Vite 使用 Rollup 作为默认的构建工具。通过运行 npm run build 命令,Vite 会将应用程序的源代码打包成一个或多个优化的静态文件,以便在生产环境中进行部署。Vite 的构建过程会根据需要进行代码拆分、压缩和优化,以…...

AI入门指南:探索人工智能的基础原理和实际应用

引言 介绍AI的基本概念:什么是人工智能,为什么它如此重要。 引出博客的主要内容,即AI的基础原理和实际应用。 第一部分:AI的基础原理 什么是人工智能: 解释AI的定义和范畴。 介绍AI的历史和发展。 机器学习入门&#x…...

使用 Webpack 从 0 到 1 构建 Vue3 项目 + ts

使用 Webpack 从 0 到 1 构建 Vue3 项目 1.初始化项目结构2.安装 webpack,补充智能提示3.初步编写 webpack.config.js3.1设置入口文件及出口文件3.2 指定 html 模板位置 4.配置 运行/打包 命令,首次打包项目5.添加 Vue 及相关配置5.1安装并引入 vue5.2 补…...

【Git】Git 分支

Git 分支 1.分支简介 为了真正理解 Git 处理分支的方式,我们需要回顾一下 Git 是如何保存数据的。 或许你还记得 起步 的内容, Git 保存的不是文件的变化或者差异,而是一系列不同时刻的 快照 。 在进行提交操作时,Git 会保存一…...

.NET Upgrade Assistant 升级 .NET MAUI

.NET Upgrade Assistant 是一种可帮助您将应用程序升级到最新的 .NET版本 的工具,并且您可以使用这个工具将您的应用程序从旧平台(例如 Xamarin Forms 和 UWP)迁移到新的平台。此外,这个新版本的工具,可以让您在不更改…...

记一次诡异的Cannot find declaration to go to,Cannot resolve method

记一次诡异的 Cannot find declaration to go to, Cannot resolve method getOnExpressions in Join 对于项目中通常问题,清除缓存,重启idea,或者仔细检查语法通常都能解决问题,但是这次却失效了,以下是原…...

智慧园区:AI边缘计算技术与视频监控汇聚平台打造智慧园区解决方案

一、行业趋势与背景 智慧园区是现代城市发展的重要组成部分,通过智能化技术提高园区的运营效率、降低成本、增强环境可持续性等具有重要作用。在智慧园区中,人工智能和视频汇聚技术是重要的前置技术。人工智能技术可以实现对数据的智能化处理和分析&…...

SpringCloud(17~21章):Alibaba入门简介、Nacos服务注册和配置中心、Sentinel实现熔断与限流、Seata处理分布式事务

17 SpringCloud Alibaba入门简介 17.1 why会出现SpringCloud alibaba Spring Cloud Netflix项目进入维护模式 https://spring.io/blog/2018/12/12/spring-cloud-greenwich-rc1-available-now 说明 Spring Cloud Netflix Projects Entering Maintenance Mode 什么是维护模…...

Jmeter安装与测试

目录 一:JMeter简介: 二:JMeter安装与配置 三:JMeter主要原件 一:JMeter简介: JMeter,一个100%的纯Java桌面应用,由Apache组织的开放源代码项目,它是功能 …...

java开发环境从0开始 【汇总版】

java开发环境从零开始 第一步:jdk第二步:安装 mysql第三步:安装maven第四步:idea最新免费安装第五步:安装navicate第六步 :安装git, 第一步:jdk 第一步当然是最先安装java开发环境啦。 看这个链…...

线性代数的本质(九)——二次型与合同

文章目录 二次型与合同二次型与标准型二次型的分类度量矩阵与合同 二次型与合同 二次型与标准型 Grant:二次型研究的是二次曲面在不同基下的坐标变换 由解析几何的知识,我们了解到二次函数的一次项和常数项只是对函数图像进行平移,并不会改变…...

STM32WB55开发(4)----配置串口打印Debug调试信息

STM32WB55开发----4.配置串口打印Debug调试信息 概述硬件准备视频教学样品申请选择芯片型号配置时钟源配置时钟树RTC时钟配置查看开启STM32_WPAN条件配置HSEM配置IPCC配置RTC启动RF开启蓝牙开启串口调试配置蓝牙参数设置工程信息工程文件设置Keil工程配置代码配置结果演示 概述…...

OpenHarmony标准系统选Linux内核,为啥首选LTS版本?聊聊4.19、5.10和6.6的适配实战

OpenHarmony标准系统选Linux内核:LTS版本决策逻辑与实战适配指南 当OpenHarmony标准系统遇上Linux内核选型,技术决策者们往往面临一个关键抉择:是追求前沿特性拥抱最新稳定版,还是坚守长期支持(LTS)版本的稳…...

DLSS Swapper:智能管理游戏DLSS版本,轻松优化画质与性能

DLSS Swapper:智能管理游戏DLSS版本,轻松优化画质与性能 【免费下载链接】dlss-swapper 项目地址: https://gitcode.com/GitHub_Trending/dl/dlss-swapper DLSS Swapper是一款专为NVIDIA显卡用户设计的智能DLSS动态链接库管理工具,能…...

告别硬件!用Proteus8.9和VSPD虚拟串口,5分钟搞定51单片机串口通信仿真

零成本玩转51单片机串口通信:Proteus与VSPD虚拟串口实战指南 记得刚接触单片机开发时,最头疼的就是硬件问题——买开发板要钱,买USB转串口模块要钱,连杜邦线都得精打细算。直到发现ProteusVSPD这对黄金组合,才明白原来…...

Simple Comic:Mac平台的开源漫画阅读解决方案

Simple Comic:Mac平台的开源漫画阅读解决方案 【免费下载链接】Simple-Comic OS X comic viewer 项目地址: https://gitcode.com/gh_mirrors/si/Simple-Comic 你是否曾遇到这样的困扰:在Mac上尝试打开漫画文件时,不是格式不兼容就是阅…...

ComfyUI DWPose预处理器GPU加速终极指南:三步解决ONNX运行时故障

ComfyUI DWPose预处理器GPU加速终极指南:三步解决ONNX运行时故障 【免费下载链接】comfyui_controlnet_aux 项目地址: https://gitcode.com/gh_mirrors/co/comfyui_controlnet_aux 在ComfyUI生态系统中,DWPose预处理器作为姿态估计的核心组件&am…...

python汽车4s店的汽车租赁服务管理系统vue

目录功能模块分析租赁服务核心功能技术实现要点扩展功能建议项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作功能模块分析 用户管理模块 用户注册与登录:支持手机号、邮箱注册,集成短信验证码功能。权限…...

通义千问3-4B-Instruct-2507调优技巧:提高指令遵循准确率

通义千问3-4B-Instruct-2507调优技巧:提高指令遵循准确率 通义千问3-4B-Instruct-2507,这个听起来有点长的名字,其实是一个特别适合我们普通开发者和爱好者玩转的AI小模型。它只有40亿参数,但阿里在2025年8月把它开源出来的时候&…...

.NET 11 预览版1:CoreCLR 在 WebAssembly 上的全面集成与性能突破

摘要随着.NET 11 Preview 1 的正式发布,.NET 生态系统迎来了一次具有分水岭意义的基础架构演进。本次发布的核心亮点在于.NET 的 CoreCLR 运行时现在已经能够原生运行在 WebAssembly (WASM) 平台上。这是一个重大的技术突破,标志着微软在跨平台战略上的全…...

数电技术实战解析04:CMOS门电路设计与优化

1. CMOS反相器:数字世界的开关艺术 第一次拆解CMOS反相器时,我被它的精妙设计震撼到了——就像家里电灯的双控开关,只不过这个"开关"的尺寸只有头发丝的万分之一。这个由PMOS和NMOS管组成的经典结构,构成了所有数字电路…...

Halcon机器视觉实战:表面划痕检测的优化策略与形态学处理

1. 表面划痕检测的工业挑战与Halcon优势 在工业质检领域,表面划痕检测一直是让工程师头疼的难题。想象一下汽车发动机缸体上的发丝状划痕,或是手机玻璃盖板上若隐若现的加工痕迹——这些缺陷往往与背景对比度差异不足5%,人眼盯着看十分钟都可…...