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

zset分页查询死循环问题

1.问题

当zset的score有较多相同值,通过ZREVRANGEBYSCORE等命令查询时,可能出现死循环,查询不完的情况。

2.解决方案

2.1 计算offset

每次查询完一页后,计算ZREVRANGEBYSCORE查询的最小值,判断和前一个值是否相等,

  1. 如果相等,继续计算,最多offset是本次的page_size,那么offset加上page_size;如果出现有重复的,可将page_size*2拉取。
  2. 如果不相等,说明分数目前没有重复,则offset默认为1,下次查询时会偏移一个返回,不会重复。

这种方式,offset越大复杂度越高,O(offset + limit)

2.2 构造唯一score

若使用时间戳作为分数,业务上同一时间戳有很多并发,那么说明该分数并不适合,可以构造唯一分数来解决:

score = 秒级ts *1e6 + count

2.3 两次查询

使用offset虽然简单,但性能可能会有所下降,可以分两次查询:

上一次查询结果:

(last_ts, last_member)

下次查询:

(ts < last_ts) OR (ts == last_ts AND member < last_member)

那么命令:

ZRANGEBYSCORE key last_ts last_ts // 查到所有分数相同的,当数量 n < page_size 时 ZREVRANGEBYSCORE key (last_ts -inf LIMIT 0 (page_size - n) // 再查询分数更小的

复杂度有点高,多了来回的网络开销。

http://www.cnnetsun.cn/news/50720.html

相关文章:

  • 零基础入门:用Cursor免费版写出你的第一行代码
  • 零基础入门:用大模型开启AI学习之旅
  • 零基础图解MinGW安装:小学生都能看懂
  • 对比评测:5种Ubuntu中文输入法的输入效率差异
  • Bosque语言:正则化编程范式的技术革命
  • 腾讯开源Hunyuan-7B-Instruct-AWQ-Int4:重塑大模型多场景部署范式
  • GKD订阅管理终极指南:2025年高效配置与使用技巧
  • Spring Boot依赖传输失败的5种实战解决方案
  • 开源PIM系统:unopim企业级产品信息管理解决方案
  • 用AI快速开发java17新特性应用
  • AI如何帮你解决Gradle插件应用异常问题
  • Tsukimi:重新定义你的Emby媒体播放体验
  • Sigmoid函数:AI模型中的激活函数核心
  • mac 安装brew零基础入门指南
  • CreamInstaller终极指南:一站式游戏DLC解锁完整教程
  • PSU必须配监控单元吗?一文讲透电源监控的配置逻辑
  • 条码扫描技术选型指南:5分钟搞定ZXing与竞品对比
  • YOLOv5 2025革新:动态损失函数突破多尺度检测瓶颈,边缘智能应用提速
  • 零基础教程:用ZyperWin开发你的第一个Windows程序
  • 零基础教程:Ubuntu ISO下载完全指南
  • 企业级应用中的中文编码实战:chcp 65001应用场景
  • AI如何革新媒体内容管理?Mediago开发实战
  • 1小时快速开发:打造你自己的.deb安装器原型
  • 企业级应用:Windows系统OpenSSL证书管理实战
  • 基于vue的图书预约借阅管理设计与实现_bcpi4d91_springboot php python nodejs
  • 如何高效管理视频文件:Seal智能命名完整指南
  • 如何用AI解决getInputStream()重复调用问题
  • AI助力GitLab本地部署:智能配置与自动化管理
  • 企业级.deb包部署实战:从单机到批量安装
  • 1小时验证创意:用神速Down打造下载加速器原型