零基础学习Redis(10) -- zset类型命令使用

2024-09-09 17:04

本文主要是介绍零基础学习Redis(10) -- zset类型命令使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。

1. zset常用命令

1.1 zadd

 zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

 使用时,在key中添加一对或多对 [score,member] ,返回添加成功的元素数量。

NX代表只有当member 不存在时才会添加成功,XX代表只有当menmber存在时才会添加成功,此时操作为更新score,不写则,member存在时为更新操作,不存在则为添加操作。

注意:更新操作不会增加zadd返回的值

GT表示只有当添加的元素不存在或者更新的score大于原来的score才会成功;LT表示只有当添加的元素不存在或者更新的score小于原来的score才会成功

CH:使zadd语句的返回值包含被修改的元素数量:

INCR :当添加的元素存在时,不是更新score而且在原来的值上增加score,并返回添加后的值,使用这个选项后,每次zadd命名只能操作一个元素。

1.2 zrange / zrevrange

zrange key start stop [WITHSCORES]

返回区间内的元素,加上withscores会连同score一起返回:

zrevrange key start stop [WITHSCORES]

和zrange类似,不过是按降序输出:

1.3 zcard 

zcard key 

返回key中的元素数量 

1.4 zcount

zcount key min max

返回分数在min 和 max之间的元素,闭区间:

排除min:

排除max:

zcount 的时间复杂度是logn

zset内存了每个元素的排名, 所有这里只需通过二分查找,找到min和max,通过减法即可得到元素数量。

min和max可以为两个特殊的值, -inf 和 inf 代表负无穷大和正无穷大:

1.5 zrangebyscore 

zrangebyscore key min max [withscores] 

返回score在 min,max之内的元素:

1.6 zpopmax / zpopmin

zpopmax key [count] 

删除并返回score最大的count个元素,删除一个元素的时间复杂度是O(logN):

zpopmin则是删除最小得元素,用法和zpopmax相同 

1.7 bzpopmax / bzpopmin

 bzpopmax key [key ...] timeout

bzpopmax是zpopmax带阻塞的版本,并且可以同时等待多个key,使用时必须设置超时时间单位是秒,可以写作小数,会返回对应得key和元素:

 同理,bzpopmin用法类似

1.8 zrank / zrevrank

 zrank key member

获取元素member的排名,元素不存在则返回nil:

zrevrank key member 

获取元素的逆序排名:

1.9 zscore 

zscore key member 

返回元素的score:

1.10 zrem 

zrem key member [ member ...] 

删除一个或多个member,返回删除成功的数量:

1.11 zremrangebyrank 

zremrangebyrank key start stop 

删除指定区间内的元素,返回删除的数量:

1.12 zincrby

  zincrby increment member 

对指定member的score增加increment,increment可以为小数和负数,返回增加后member的score:

1.13 zinterstore / unionstore

zinterstore destination numkeys key [key ...] [WEIGHTS weight [ weight ...]] [aggregate < sum | min | max>]

  •  对多个key做交集,结果存入destination
  • numkeys代表key的数量,weights代表每个key的权重,计算时,score会乘以权重
  • aggregate ,相同key的score的计算方式,sun代表求和,min取小的,max取大的默认是sum

 

key1权重是1,key2权重是5,计算时分数会乘以权重,所有key3中的b分数是16 + 5 = 21

unionstore用于求并集,用法和zinterstore相同

2. zset编码方式

zset有两种编码方式:

  • ziplist:如果有序集合中的元素个数比较少,或单个元素体积比较小,就会使用压缩列表,节省空间
  • skiplist:如果元素数量比较多,或单个元素体积较大就会使用跳表来存,跳表是一个复杂链表,查询复杂度是logN,并且更适合范围查找数据

其中编码方式转换的阈值可以在配置文件中进行设置 

3. zset应用场景 

zset最主要的应用场景是排行榜系统 

游戏分数排行:只需把玩家信息和分数存储到zset中即可,自动就会形成了一个排行榜,分数发生变化可以通过zincrby修改分数,排名也会自动动态调整(logN)

**热搜:这类场景通常是用综合数值决定排名的,例如,点赞数,评论数,转发量,可以分别使用zset存储,然后通过 zinterstore计算各个数值的综合得分(可以设置权重等)得到排行榜

这篇关于零基础学习Redis(10) -- zset类型命令使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1151756

相关文章

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

python之uv使用详解

《python之uv使用详解》文章介绍uv在Ubuntu上用于Python项目管理,涵盖安装、初始化、依赖管理、运行调试及Docker应用,强调CI中使用--locked确保依赖一致性... 目录安装与更新standalonepip 安装创建php以及初始化项目依赖管理uv run直接在命令行运行pytho

redis数据结构之String详解

《redis数据结构之String详解》Redis以String为基础类型,因C字符串效率低、非二进制安全等问题,采用SDS动态字符串实现高效存储,通过RedisObject封装,支持多种编码方式(如... 目录一、为什么Redis选String作为基础类型?二、SDS底层数据结构三、RedisObject

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

Kotlin 枚举类使用举例

《Kotlin枚举类使用举例》枚举类(EnumClasses)是Kotlin中用于定义固定集合值的特殊类,它表示一组命名的常量,每个枚举常量都是该类的单例实例,接下来通过本文给大家介绍Kotl... 目录一、编程枚举类核心概念二、基础语法与特性1. 基本定义2. 带参数的枚举3. 实现接口4. 内置属性三、

Java List 使用举例(从入门到精通)

《JavaList使用举例(从入门到精通)》本文系统讲解JavaList,涵盖基础概念、核心特性、常用实现(如ArrayList、LinkedList)及性能对比,介绍创建、操作、遍历方法,结合实... 目录一、List 基础概念1.1 什么是 List?1.2 List 的核心特性1.3 List 家族成

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Python使用python-pptx自动化操作和生成PPT

《Python使用python-pptx自动化操作和生成PPT》这篇文章主要为大家详细介绍了如何使用python-pptx库实现PPT自动化,并提供实用的代码示例和应用场景,感兴趣的小伙伴可以跟随小编... 目录使用python-pptx操作PPT文档安装python-pptx基础概念创建新的PPT文档查看

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点

MySQL中优化CPU使用的详细指南

《MySQL中优化CPU使用的详细指南》优化MySQL的CPU使用可以显著提高数据库的性能和响应时间,本文为大家整理了一些优化CPU使用的方法,大家可以根据需要进行选择... 目录一、优化查询和索引1.1 优化查询语句1.2 创建和优化索引1.3 避免全表扫描二、调整mysql配置参数2.1 调整线程数2.