redis 有序集合zrange和zrangebyscore的区别

起因是查询数据,用了zrangebyscore 但是一直显示没数据

具体命令zrangebyscore key 0 -1 withscores, 原有印象中一直是这么用的,但是突然查不出来了, 于是搜了下问题所在。

通过分数查看 不能用0和-1表示最小和最大,只能用分数来指定范围
zrevrangebyscore key +inf -inf withscores 按score 从大到小排
zrangebyscore key -inf +inf withscores 按score从小到大排

-inf:代表负无穷大,意味着分数下限没有限制。

+inf:代表正无穷大,意味着分数上限没有限制。
zange key 0 -1 withscores 是通过索引进行查看,所以能用0和-1

下面是具体的区别:

在 Redis 中,ZRangeZRangeByScore 都是用于从有序集合(ZSet)中获取元素的命令,但它们的使用方式和应用场景有所不同,下面为你详细介绍:

基本语法

  • ZRange
plaintext 复制代码
ZRANGE key start stop [WITHSCORES]
  • ZRangeByScore
plaintext 复制代码
ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]

具体区别

1. 查询依据不同
  • ZRange:依据元素在有序集合中的索引位置来获取元素。有序集合中的元素按照分数从小到大排序,索引从 0 开始。可以使用负数索引,-1 表示最后一个元素,-2 表示倒数第二个元素,以此类推。
  • ZRangeByScore :依据元素的分数范围来获取元素。通过指定最小分数(min)和最大分数(max),可以获取分数在这个范围内的所有元素。
2. 参数含义不同
  • ZRange
    • key:有序集合的键名。
    • start:起始索引。
    • stop:结束索引。
    • [WITHSCORES]:可选参数,若指定该参数,结果会同时返回元素及其分数。
  • ZRangeByScore
    • key:有序集合的键名。
    • min:分数范围的最小值,可以使用 -inf 表示负无穷大。
    • max:分数范围的最大值,可以使用 +inf 表示正无穷大。
    • [WITHSCORES]:可选参数,若指定该参数,结果会同时返回元素及其分数。
    • [LIMIT offset count]:可选参数,用于分页,offset 表示偏移量,count 表示返回的元素数量。
3. 使用场景不同
  • ZRange:适用于需要按照元素在有序集合中的顺序获取元素的场景,例如获取排行榜的前 N 名、后 N 名等。
  • ZRangeByScore:适用于需要根据元素的分数范围来获取元素的场景,例如获取分数在某个区间内的所有元素、获取分数高于或低于某个值的所有元素等。

示例代码

plaintext 复制代码
# 向有序集合中添加元素
ZADD myzset 1 "one" 2 "two" 3 "three" 4 "four" 5 "five"

# 使用 ZRange 获取所有元素
ZRANGE myzset 0 -1 WITHSCORES

# 使用 ZRangeByScore 获取分数在 2 到 4 之间的元素
ZRANGEBYSCORE myzset 2 4 WITHSCORES

总结

  • ZRange 基于索引位置获取元素,更关注元素在有序集合中的顺序。
  • ZRangeByScore 基于分数范围获取元素,更关注元素的分数。

在实际使用中,需要根据具体的需求选择合适的命令。

相关推荐
转身後 默落1 小时前
01.Redis 概述
数据库·redis·缓存
你的人类朋友3 小时前
❤️‍🔥为了省内存选择sqlite,代价是什么
数据库·后端·sqlite
飞翔的佩奇3 小时前
基于SpringBoot+MyBatis+MySQL+VUE实现的名城小区物业管理系统(附源码+数据库+毕业论文+开题报告+部署教程+配套软件)
数据库·vue.js·spring boot·mysql·毕业设计·mybatis·小区物业管理系统
小白不想白a3 小时前
【MySQL】MySQL的安全风险与安装安全风险
linux·数据库·mysql·安全
折翼的恶魔3 小时前
SQL148 返回产品名称和每一项产品的总订单数
数据库
技术不支持4 小时前
Qt Creator 11.0.3 语法高亮bug问题
java·服务器·数据库·qt·bug
止水编程 water_proof4 小时前
MySQL——增删改查操作
数据库·mysql
gs801405 小时前
GitLab Docker Compose 迁移后 Redis 权限问题排查与解决
redis·docker·gitlab
葵野寺6 小时前
【MySQL】MySQL索引—B树/B+树
数据库·b树·mysql·b+树
隔壁老登6 小时前
解决dbeaver连接不上oceanbase数据库的问题
数据库·oceanbase