Redis zinterstore

Redis zinterstore (有序集合交集存储)

一、作用

zinterstore把多个 ZSet 有序集合做交集 ,并把结果存入一个新的 ZSet自动覆盖目标 key

语法:

redis

复制代码
zinterstore 目标key 数量 集合1 集合2 [集合3...] [weights 权重] [aggregate sum/min/max]

二、核心规则

  1. 只保留同时出现在所有 ZSet 里的成员(交集)
  2. 交集后的分数 可以按 sum、min、max 合并计算
  3. 第一个参数是目标 key原有数据直接被覆盖(和 set 的 sinterstore 一个设计逻辑)
  4. 第二个参数要写参与计算的集合个数,不能漏

三、最简示例

准备两个有序集合:

redis

复制代码
zadd rank:a 10 张三 20 李四 30 王五
zadd rank:b 15 李四 25 王五 35 赵六

求交集,存入 rank:inter

redis

复制代码
zinterstore rank:inter 2 rank:a rank:b

交集成员:李四、王五 默认分数规则:sum 累加

  • 李四:20+15 = 35
  • 王五:30+25 = 55

查看结果:

redis

复制代码
zrange rank:inter 0 -1 withscores

四、自定义聚合规则

1. 取分数最小值

redis

复制代码
zinterstore rank:inter 2 rank:a rank:b aggregate min

2. 取分数最大值

redis

复制代码
zinterstore rank:inter 2 rank:a rank:b aggregate max

五、权重 weights 用法

给每个集合的分数先乘权重,再聚合:

redis

复制代码
zinterstore rank:inter 2 rank:a rank:b weights 2 1 aggregate sum

意思:

  • rank:a 每个分数 ×2
  • rank:b 每个分数 ×1
  • 再按 sum 相加

六、应用场景

  1. 共同好友 + 带权重排序两个人共同好友,再按亲密值 / 互动分排序。

  2. 多条件榜单筛选同时满足「付费用户」「活跃用户」两个 ZSet,交集后生成精准榜单。

  3. 商品多维度评分合并销量、好评、热度多个榜单,交集后加权算出综合排名。

  4. 推荐系统过滤从候选推荐列表中,过滤掉已浏览、已拉黑用户,保留交集并重新计分排序。

七、一句话总结

zinterstoreZSet 交集并持久化 ,可对分数做 sum/min/max 聚合,支持权重,目标 key 会直接覆盖旧数据,适合做带分数排序的共同关系、多条件筛选、加权排行榜。

相关推荐
xieliyu.8 分钟前
Java算法精讲:双指针(二)
java·开发语言·算法
wayz1143 分钟前
Momentum:PSL(心理线指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
8Qi82 小时前
LeetCode 213:打家劫舍 II(House Robber II)—— 题解 ✅
算法·leetcode·职场和发展·动态规划
三品吉他手会点灯2 小时前
C语言学习笔记 - 44.运算符和表达式 - 运算符2 - 除法与取余运算符
c语言·开发语言·笔记·算法
乐迪信息2 小时前
乐迪信息:AI算法盒子实时识别船舶烟雾与火焰异常
大数据·人工智能·算法·安全·目标跟踪
J-Tony112 小时前
【JVM】根可达算法
jvm·算法
艾iYYY2 小时前
string 类的模拟实现
android·服务器·c语言·c++·算法
Lsk_Smion3 小时前
力扣实训 _ [75].颜色分类 _ 杨辉三角
数据结构·算法·leetcode
jidaowansui3 小时前
P11375 [GESP202412 六级] 树上游走
数据结构·算法