Redis--Zset类型

news2025/3/17 17:07:08

目录

一、引言

二、介绍

三、命令

1.zadd

2.zrange,zrevrange,zrangebyscore

3.zcard,zcount

4.zpopmax,bzpopmax,zpopmin,bzpopmin

5.zrank,zrevrank,zscore

6.zrem,zremrangebyrank,zremrangebyscore 

7.zincrby

8.zinterstore

9.zunionstore

四、内部编码

1.ziplist(压缩列表)

2.skiplist(跳表)

五、应用场景

1.排行榜系统

2.进行加权排行

六、总结


一、引言

  本篇文章我们就redis的value的类型zset类型进行简单的介绍,以及其相关命令和应用场景。

二、介绍

  zset:有序集合,zset中的member引入了一个属性score,浮点类型,排序的时候就是按照分数的大小进行升序/降序的排序。

三、命令

1.zadd

  zadd:往有序集合中添加元素和分数,对于有序集合来说,即可通过member来找到score,也可以通过score来找到匹配的member。

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

XX:更新当前存在的,不存在就操作失败

NX:添加新的,对于已经存在的就操作失败

LT:对于已经存在的,如果新的分数比当前分数小就更新

GT:对于已经存在的,如果新的分数比当前分数大就更新

CH:zadd返回的是本次添加的元素,指定这个选项之后就会包含本次更新的元素个数    

INCR:对现有分数进行一个数值操作

Zset添加元素的时间复杂度是O(logN)

zset内部实际用的就是升序排序的

2.zrange,zrevrange,zrangebyscore

zrange:查看元素的详情

zrevrange:默认是升序排序,使用zrevrange变成降序排序

zrangebyscore:按照分数查找元素

3.zcard,zcount

zcard:获取元素个数  时间复杂度:O(1)

zcount:返回分数在min和max之间的元素个数  时间复杂度:O(logN)

4.zpopmax,bzpopmax,zpopmin,bzpopmin

zpopmax:删除并返回分数最高的元素   时间复杂度:O(logN * M)

bzpopmax:阻塞版本的zpopmax,可以设置超时时间,没有元素才阻塞。时间复杂度:O(logN)

zpopmin:删除并返回分数最低的元素

bzpopmin:阻塞版本的zpopmin,可以设置超时时间,没有元素才阻塞。时间复杂度:O(logN)

5.zrank,zrevrank,zscore

zrank:返回指定元素的排名,升序   时间复杂度:O(logN)

zrevrank:返回指定元素的排名,降序

zscore:获取元素对应的分数   时间复杂度:O(1)

6.zrem,zremrangebyrank,zremrangebyscore 

zrem:删除元素       时间复杂度:O(logN * M)

zremrangebyrank:范围删除   

zremrangebyscore:根据分数删除

7.zincrby

zincrby:增加分数   返回增加之后的分数值

8.zinterstore

  zinterscore:求交集,将结果保存到另一个key中   时间复杂度:O(N*K)+O(M*log(M))  近似看作O(M*log(M))

zinterstore dest keynums key key2 weights 2 3

9.zunionstore

和上一个命令类似,只是这个是求并集

四、内部编码

1.ziplist(压缩列表)

如果有序集合中的元素较少,或者单个元素的体积较小,此时使用ziplist进行存储

2.skiplist(跳表)

元素较多,或者元素体积较大。

跳表是一个复杂的链表   查询一个元素的时间复杂度是O(logN)  更擅长按照范围获取元素

五、应用场景

1.排行榜系统

2.进行加权排行

利用相关操作对某种特性进行加权计算再进行排行

六、总结

  本篇文章,简单介绍了value的类型zset类型的相关命令,内部编码以及应用场景,下一篇文章咱们将补充一些其他不常见的类型,感谢观看!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2316724.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《阿里云Data+AI:开启数据智能新时代》电子书上线啦!

本书整理了阿里云在DataAI领域的最新实践案例与深度洞察,涵盖电商、游戏、营销、数字内容等多个行业的成功经验,以及技术专家对数据库与AI融合趋势的专业解读。 通过理论与实践的结合,我们将共同探索DataAI如何成为企业智能化转型的核心驱动…

Golang编译器DIY,手搓 if err != nil { return err } 语法糖

前序 在go的社区里,下面这三行代码是被吐槽的最多的 if err ! nil {return err }从代码之整洁美观的角度看,这样的写法也是让人不舒服的。尤其是 当有很多错误需要处理的时候,就会发现通篇都是这三行。 所以想着看看修改一下编译器&#xf…

图解多头注意力机制:维度变化一镜到底

目录 一、多头注意力机制概述二、代码实现1. pyTorch 实现2. tensorFlow实现 三、维度变化全流程详解1. 参数设定2. 维度变化流程图3. 关键步骤维度变化 四、关键实现细节解析1. 多头拆分与合并2. 注意力分数计算3. 掩码处理技巧 五、完整运行示例六、总结与常见问题1. 核心优势…

[ISP] 人眼中的颜色

相机是如何记录颜色的,又是如何被显示器还原的? 相机通过记录RGB数值然后显示器显示RGB数值来实现颜色的记录和呈现。道理是这么个道理,但实际上各厂家生产的相机对光的响应各不相同,并且不同厂家显示器对三原色的显示也天差地别&…

解锁MySQL 8.0.41源码调试:Mac 11.6+CLion 2024.3.4实战指南

文章目录 解锁MySQL 8.0.41源码调试:Mac 11.6CLion 2024.3.4实战指南前期准备环境搭建详细步骤安装 CLion安装 CMake 3.30.5准备 MySQL 8.0.41 源码配置 CMake 选项构建 MySQL 项目 调试环境配置与验证配置 LLDB 调试器启动调试验证调试环境 总结与拓展 解锁MySQL 8…

关于xcode Project navigator/项目导航栏的一些说明

本文基于 xcode12.4 版本做说明 首先要明确一点,导航栏这里展示的并不是当前工程在电脑硬盘中的文件结构,它展示的是xxxxxx.xcodeproj/project.pbxproj文件(后文简.pbxproj文件)中的内容。我们在导航栏中的操作就是修改该文件,有些操作会修…

深度解析扣减系统设计:从架构到实践

背景 在当今数字化业务蓬勃发展的时代,扣减系统在众多业务场景中扮演着关键角色。无论是电商平台的库存扣减,还是金融领域的资金扣减、积分系统的积分扣减,一个高效、可靠且数据一致的扣减系统都是业务稳健运行的基石。本文将深入探讨扣减系…

视觉定位项目中可以任意修改拍照点位吗?

修改拍照点位不是那么简单 1. 背景2. 修改拍照点位意味着什么?3. 如何解决这个问题? 1. 背景 在视觉定位的项目中,会遇到这么一种情况:完成三步(9点标定,旋转中心标定,示教基准)之…

深度学习常用操作笔记

深度学习常用操作笔记 指令报错cannot import name Config from mmcvImportError: cannot import name print_log from mmcvImportError: cannot import name init_dist from mmengine.runnerWARNING: Retrying (Retry(total4, connectNone, readNone, redirectNone, statusNon…

C++学习内存管理

1.概念的介绍 总括: 1. 栈(Stack) 存储内容: 局部变量(包括函数参数、非静态局部变量)。 函数调用的上下文信息(如返回地址、寄存器状态等)。 特点: 内存由编译器自动…

git使用。创建仓库,拉取分支,新建分支开发

文章目录 安装 git自己新建仓库,进行代码管理合作开发的流程拉去主分支代码查看本地分支的状态查看远程分支查看远程的仓库信息本地分支切换切换并创建分支提交代码 made by NJITZX git 是一个版本控制工具,真正开发项目中是多个人开发一个项目的&#…

itsdangerous加解密源码分析|BUG汇总

这是我这两天的思考 早知道密码学的课就不旷那么多了 纯个人见解 如需转载,标记出处 目录 一、官网介绍 二、事例代码 源码分析: 加密函数dump源码使用的函数如下: 解密 ​编辑 ​编辑 关于签名: 为什么这个数字签名没有…

不像人做的题————十四届蓝桥杯省赛真题解析(上)A,B,C,D题解析

题目A:日期统计 思路分析: 本题的题目比较繁琐,我们采用暴力加DFS剪枝的方式去做,我们在DFS中按照8位日期的每一个位的要求进行初步剪枝找出所有的八位子串,但是还是会存在19月的情况,为此还需要在CHECK函数…

JavaScript 中 call 和 apply 的用法与区别

文章目录 前言一、 call 方法1.1 基本用法1.2 传递多个参数 二、apply 方法2.1 基本用法2.2 传递数组参数 三、call 和 apply 的区别四、实际应用场景4.1 借用方法4.2 继承与构造函数 五、总结 前言 在 JavaScript 中,call 和 apply 是两个非常重要的函数方法&…

面试系列|蚂蚁金服技术面【1】

哈喽,大家好!今天分享一下蚂蚁金服的 Java 后端开发岗位真实社招面经,复盘面试过程中踩过的坑,整理面试过程中提到的知识点,希望能给正在准备面试的你一些参考和启发,希望对你有帮助,愿你能够获…

使用傅里叶变换测量声卡的频率失真

文章目录 一、说明二、关于声卡的技术详述三、实验代码获取四、结论 一、说明 假如我希望使用我的声卡来模拟软件无线电,利用声音而不是射频信号。我的声卡能胜任这项任务吗?本文将研究一种技术来找出答案。另外,需要了解音频技术的读者也可…

【HTML5】01-HTML摆放内容

本文介绍HTML5摆放标签的知识点。 目录 1. HTML概念 2. HTML骨架 3. 标签的关系 4. 标题标签 5. 段落标签 6. 换行和水平线 7. 文本格式化标签 8. 图像标签 图像 - 属性 9. 路径 相对路径 绝对路径 10. 超链接标签 11. 音频标签 12. 视频标签 1. HTML概念 HTM…

内存管理:

我们今天来学习一下内存管理: 1. 内存分布: 我们先来看一下我们下面的图片: 这个就是我们的内存,我们的内存分为栈区,堆区,静态区,常量区; 我们的函数栈帧开辟消耗的内存就是我们…

设计模式使用Java案例

代码设计要有可维护性,可复用性,可扩展性,灵活性,所有要使用设计模式进行灵活设计代码 创建型 简单工厂模式(Simple Factory) 简单工厂模式(Simple Factory Pattern)是一种创建型…

模运算的艺术:从基础到高阶的算法竞赛应用

在算法竞赛中,模运算(取模运算)是一个非常重要的概念,尤其在处理大数、防止溢出、以及解决与周期性相关的问题时。C 中的模运算使用 % 运算符,但它的行为和使用场景需要特别注意。 1. 模运算的基本概念 模运算是指求一…