详解redis(9):数据结构set

一、Redis Set 是什么

Set = 不重复 + 无顺序的集合

一个 自动去重不关心顺序 的容器

二、Set 和 List 的本质区别

对比项 List Set
是否允许重复 ✅ 允许 ❌ 不允许
是否有顺序 ✅ 有顺序(下标) ❌ 无序
能否按下标访问 ✅ LINDEX ❌ 不支持
是否支持集合运算 ✅ 交集 / 并集 / 差集
典型使用场景 消息队列、时间线 去重、关系、标签

三、Set 能干什么

交集(共同好友)

bash 复制代码
SINTER user:1:friends user:2:friends

并集(所有好友)

bash 复制代码
SUNION user:1:friends user:2:friends

差集(你有我没有)

bash 复制代码
SDIFF user:1:friends user:2:friends

四、底层结构一:整数集合

使用条件(必须同时满足)

所有元素都是整数

元素个数 < 512(默认,可配置)

本质:连续内存数组

特点:

有序存储(但对外仍然无序)

紧凑、节省内存

使用二分查找

只支持整数

五、底层结构二:哈希表

什么时候用?

元素不是纯整数

或元素数量很多

优点

O(1) 级别的增删查

支持任意字符串

支持大规模数据

缺点

内存占用比 intset 高

有 rehash 成本

六、两种实现对比总结

维度 intset hash table
元素类型 仅整数 任意
数据规模 小(<512)
内存占用 极低 较高
查询方式 二分查找 哈希
是否自动升级 → hash 不可降级

七、为什么抽奖活动非常适合用 Set?

抽奖的核心需求其实就 4 个字:

去重 + 随机

抽奖需求 Set 特性
同一用户不能重复参与 Set 天然去重
参与顺序无所谓 Set 无序
随机抽人 SRANDMEMBER / SPOP
统计参与人数 SCARD
相关推荐
rchmin2 分钟前
向量数据库Milvus安装及使用实战经验分享
数据库·milvus
ego.iblacat8 分钟前
Python 连接 MySQL 数据库
数据库·python·mysql
祖传F8719 分钟前
quickbi数据集数据查询时间字段显示正确,仪表板不显示
数据库·sql·阿里云
Leon-Ning Liu39 分钟前
Oracle 26ai新特性:时区、表空间、审计方面的新特性
数据库·oracle
humors2211 小时前
各厂商工具包网址
java·数据库·python·华为·sdk·苹果·工具包
Yushan Bai1 小时前
ORACLE数据库在进行DROP TABLE时失败报错ORA-00604问题的分析处理
数据库·oracle
難釋懷2 小时前
缓存同步
spring·缓存·mybatis
77美式2 小时前
Node + Express + MongoDB 后端部署全解析:新手零踩坑
数据库·mongodb·express
城数派2 小时前
2000-2025年我国省市县三级逐8天日间地表温度数据(Shp/Excel格式)
数据库·arcgis·信息可视化·数据分析·excel
AC赳赳老秦2 小时前
OpenClaw text-translate技能:多语言批量翻译,解决跨境工作沟通难题
大数据·运维·数据库·人工智能·python·deepseek·openclaw