详解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
相关推荐
pixcarp6 小时前
知识库系统的内容资产闭环怎么设计
服务器·数据库·后端·golang
JosieBook6 小时前
【数据库】时序预测能力的分级进化:TimechoAI如何让每一类用户都能精准预见未来
java·开发语言·数据库
吴声子夜歌8 小时前
SQL经典实例——使用多张表
数据库·sql
倔强的石头_9 小时前
《Kingbase护城河》——深度解密数据库行锁冲突与等待事件架构
数据库
IT策士9 小时前
Redis 从入门到精通:性能调优与多语言客户端对比
数据库·redis·缓存
青柠代码录10 小时前
【Redis】数据类型:Stream
redis
Bert.Cai10 小时前
Oracle INSTR函数详解
数据库·oracle
Yeats_Liao10 小时前
Feed流系统设计(三):数据模型与存储设计,从表结构到Redis收件箱
java·javascript·redis
IronMurphy12 小时前
【算法五十七】146. LRU 缓存
算法·缓存
茉莉玫瑰花茶12 小时前
综合案例 - AI 智能租房助手 [ 5 ]
服务器·数据库·人工智能·python·ai