Redis——zset类型详解

news2024/11/18 15:32:18

概要

zset是有序集合,将zset中的members引入一个属性score,根据这个属性值来进行排序,其中members不可以重复,score可以重复(按照字典序排序),默认按照升序排序

有序集合中提供指定分数和元素范围查找,计算成员排名功能,一般用于排行榜系统

zset中的member和score并不是键值对的关系,而是pair,既可以通过member找到score,也可以通过score找到member
在这里插入图片描述

常用命令

zadd

将元素和对应分数插入到有序集合中,时间复杂度O(logN),因为添加的元素要放到指定的位置上来保证有序,默认返回新增成功的元素个数
在这里插入图片描述
方括号中的内容是代表可选的选项

选项作用
XX只更新已经存在的元素,不新插入元素
NX只插入新的元素,不更新已经存在的元素
不加NX或XX当前members不存在,则添加新元素,否则更新元素分数
LT只更新已经存在的元素,并且新的分数比当前的分数小
GT只更新已经存在的元素,并且新的分数比当前的分数大
CH如果不添加CH选项,默认返回添加元素的个数,添加CH选项后,加上修改元素的个数
INCR效果相同于ZINCRBY,将指定元素的score+=指定的值,返回值是更新后score的值

zrange

查看有序集合中指定下标范围的元素详情,从0开始,支持负数(-1就是最后一个元素)

时间复杂度O(log(N) + M),其中logN是根据下标找到边界值,M是遍历区间的开销
在这里插入图片描述
添加withscores,即可查看members对应的score

示例

在这里插入图片描述
加入withscores:
在这里插入图片描述
修改操作:
在这里插入图片描述
NX选项:
添加不存在元素:
在这里插入图片描述
NX选项:
更新存在元素(不会生效):
在这里插入图片描述
XX选项:
更新存在元素的score:
在这里插入图片描述
XX选项:
更新不存在的元素的score(更新失败):
在这里插入图片描述
CH选项:
在这里插入图片描述
INCR操作:
在这里插入图片描述

zcard

获取指定key中元素个数,时间复杂度为O(1)
在这里插入图片描述

zcount

返回指定区间(前闭后闭)内的key中元素的个数,时间复杂度O(logN),(zset内部记录了每个元素的所在次序,logN的时间复杂度找到min和max,然后直接相减次序即可得到元素个数)

min和max支持使用浮点数,inf(无穷大),-inf(负无穷)
在这里插入图片描述
演示:
在这里插入图片描述
如果想要排除边界值可以加上括号
在这里插入图片描述

zrevrange

倒序获取指定范围内的元素
在这里插入图片描述
演示:
在这里插入图片描述

zrangebyscore

根据分数获取指定范围的元素,使用方法和zcount类似
在这里插入图片描述
演示:
在这里插入图片描述

zpopmax

删除并返回分数最高的count个元素

时间复杂度O(log(N) + M),N是有序集合中元素的个数,M是count的个数
在这里插入图片描述
演示:
在这里插入图片描述
如果存在score相同的多个元素,并且都是最大值,那么zpopmax仍然只删除其中的一个元素(按照字典序)
在这里插入图片描述

bzpopmax

阻塞版本的zpopmax,时间复杂度O(logN),如果传入多个key,只删除其中的一个
在这里插入图片描述
timeout是超时时间,表示最多阻塞多久,单位是秒,支持小数

演示:
客户端a中的key有序集合中没有元素,进行bzpopmax命令,阻塞等待
在这里插入图片描述
客户端b插入元素:
在这里插入图片描述
此时,客户端a就可以拿到元素了
在这里插入图片描述

zpopmin

和zpopmax一致,删除有序集合中score最小的元素
在这里插入图片描述

bzpopmin

和bzpopmax一致,阻塞删除有序集合中最小的元素
在这里插入图片描述

zrank

获取指定元素的排名,时间复杂度O(logN),member不存在返回nil
在这里插入图片描述

演示:
在这里插入图片描述

zrevrank

按照正序获取member排名
在这里插入图片描述

zscore

返回指定member的score,时间复杂度O(1)
在这里插入图片描述

zrem

删除有序集合中指定的member

时间复杂度O(log(N) * M),N是整个有序序列中元素的个数,M是要删除member的个数

返回删除成功的元素的个数
在这里插入图片描述
演示:
在这里插入图片描述

zremrangebyrank

根据指定排名范围删除member,前闭后闭,时间复杂度O(logN + M),N是整个集合的member个数,M是区间内的元素个数
在这里插入图片描述
演示:
在这里插入图片描述

zremrangebyscore

删除指定分数范围内的members,闭区间,可以使用(排除边界值,时间复杂度O(logN + M)
在这里插入图片描述

演示:
在这里插入图片描述

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

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

相关文章

使用POI实现操作Excel文件。

1、添加依赖 <dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>4.1.2</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-o…

Keras入门与残差网络的搭建

发现草稿箱里还有一篇很早之前的学习笔记&#xff0c;希望可以帮助到有需要的童鞋~ 目录 1、keras入门 2、残差网络 &#xff08;ResNet&#xff09; 2.1、恒等块 2.2、卷积块 搭建一个50层的残差网络 自己的测试数据 1、keras入门 本文参考参考 Keras模型大纲&#xff…

SSM SpringBoot vue快递柜管理系统

SSM SpringBoot vue快递柜管理系统 系统功能 登录 注册 个人中心 快递员管理 用户信息管理 用户寄件管理 配送信息管理 寄存信息管理 开发环境和技术 开发语言&#xff1a;Java 使用框架: SSM(Spring SpringMVC Mybaits)或SpringBoot 前端: vue 数据库&#xff1a;Mys…

《VulnHub》DarkHole:1

VulnHub 1&#xff1a;靶场信息2&#xff1a;打靶2.1&#xff1a;情报收集&威胁建模2.2&#xff1a;漏洞分析&渗透攻击 3&#xff1a;总结3.1&#xff1a;命令&工具3.1.1&#xff1a;Nmap 3.2&#xff1a;关键技术 VulnHub 打靶记录。官网&#xff1a;https://www.…

C++零碎记录(十)

17. 继承对象内存 17.1 查询继承对象所占内存 #include <iostream> using namespace std; #include<string>//继承中的对象模型class Base { public:int m_A; protected:int m_B; private:int m_C; };//公共继承 class Son:public Base {int m_D; };//利用开发人…

在Creo 6.0中画图模板问题

在Creo 6.0中&#xff0c;文件的默认模板是英制模板“inlbs_part_solid”,此文件模板中尺寸的单位是inch。我们建模中需要的单位是mm&#xff0c;改变Creo文件默认的单位有两种方法。 1 【新建】对话框取消勾选【使用默认模板】对话框 &#xff08;1&#xff09;单击主页选项…

从板凳围观到玩转行家:Moonbeam投票委托如何让普通用户一同参与

今年5月&#xff0c;Moonbeam发起了一项社区链上治理中投票委托反馈的调查。187位社区成员参与了这项调查&#xff0c;调查发现受访者对治理感兴趣&#xff0c;增加参与度只需要进行一些调整&#xff0c;即更简化的投票流程。 治理和去中心化是Web3的核心&#xff0c;随着Moon…

2023/9/11 qtc++

#include <iostream> #include <cstring> using namespace std; class myString { private:char *str;int size; public://无参构造myString():size(10){str new char[size]; //构造出一个长度为10的字符串strcpy(str,""); //赋值为空串}//有…

@ApiImplicitParams这个注解的作用

ApiImplicitParams这个注解的作用&#xff1f; ApiImplicitParams是一个用于描述方法参数的注解&#xff0c;它可以用在方法上&#xff0c;作用是为方法中的参数定义多个注解&#xff0c;并将这些注解集中到一个注解集中进行统一管理。通过ApiImplicitParams注解&#xff0c;我…

玩石头游戏的必胜策略-2023年全国青少年信息素养大赛Python复赛真题精选

[导读]&#xff1a;超平老师计划推出《全国青少年信息素养大赛Python编程真题解析》50讲&#xff0c;这是超平老师解读Python编程挑战赛真题系列的第17讲。 全国青少年信息素养大赛&#xff08;原全国青少年电子信息智能创新大赛&#xff09;是“世界机器人大会青少年机器人设…

Linux 操作系统云服务器安装部署 Tomcat 服务器详细教程

Tomcat 基本概述 Tomcat 服务器是Apache软件基金会&#xff08;Apache Software Foundation&#xff09;的 Jakarta 项目中的一个核心项目&#xff0c;由 Apache、Sun 和其他一些公司及个人共同开发而成。它是一个免费的开放源代码的 Web 应用服务器&#xff0c;属于轻量级应用…

融资融券开户条件和要求,融资融券开户具体流程

融资融券开户条件和要求&#xff1a;符合国家法律、行政法规规定&#xff0c;允许从事证券交易的个人和机构&#xff0c;个人客户需年满18周岁且具有完全民事行为能力&#xff0c;要求普通证券账户在公司从事证券交易不少于6个月&#xff0c;即开户需满6个月&#xff1b;拥有不…

【C++进阶】二叉树搜索树

⭐博客主页&#xff1a;️CS semi主页 ⭐欢迎关注&#xff1a;点赞收藏留言 ⭐系列专栏&#xff1a;C进阶 ⭐代码仓库&#xff1a;C进阶 家人们更新不易&#xff0c;你们的点赞和关注对我而言十分重要&#xff0c;友友们麻烦多多点赞&#xff0b;关注&#xff0c;你们的支持是我…

十三、函数式编程(2)

本章概要 方法引用 Runnable 接口未绑定的方法引用构造函数引用 函数式接口 多参数函数式接口缺少基本类型的函数 方法引用 Java 8 方法引用没有历史包袱。方法引用组成&#xff1a;类名或对象名&#xff0c;后面跟 :: &#xff0c;然后跟方法名称。 interface Callable {…

系统架构设计师-计算机网络

目录 一、计算机网络技术概述 1、网络概述 2、网络有关指标 3、网络分类 4、5G技术 二、组网技术 1、交换技术 2、基本交换原理 三、TCP/IP协议簇 1、DHCP 2、DNS 四、网络规划与设计 一、计算机网络技术概述 1、网络概述 计算机网络的功能&#xff1a; &#xff08;1&…

项目经理升级却面临挑战?如何解决任务分解和成员职责不明难题

有一个朋友刚升任项目经理。但他这两天却一副愁眉不展的样子&#xff0c;因为他之前是做技术的&#xff0c;缺乏管理经验&#xff0c;在制定计划时没有合理的分解任务&#xff0c;并且没有明确项目成员的职责&#xff0c;导致项目在推进过程中项目进度不清晰。 项目管理涉及到…

Mendeley在linux中无法打开APPimage

原因:FUSE 库为用户空间程序提供了一个接口&#xff0c;可以将虚拟文件系统导出到 Linux 内核。由于缺少这个关键库&#xff0c;AppImage 无法按预期工作。 1 安装fuse,打开终端,输入命令 sudo apt install libfuse2 输入用户密码结,果如下 2 确保APPimage作为程序运行 右击…

在阿里云 linux 服务器上查看当前服务器的Nginx配置信息

我们可以通过命令 sudo nginx -t查看到nginx.conf的路径 可以通过 sudo nginx -T查看 nginx 详细配置信息&#xff0c;包括加载的配置文件和配置块的内容 其中也会包括配置文件的内容

【k8s】Kubernetes版本v1.17.3 kubesphere 3.1.1 默认用户登录失败

1.发帖&#xff1a; Kubernetes版本v1.17.3 kubesphere 3.11 默认用户登录失败 - KubeSphere 开发者社区 2. 问题日志&#xff1a; 2.1问题排查方法 &#xff1a; 用户无法登录 http://192.168.56.100:30880/ 2.2查看用户状态 kubectl get users [rootk8s-node1 ~]# k…

Java 多线程系列Ⅶ(线程安全集合类)

线程安全集合类 前言一、多线程使用线性表二、多线程使用栈和队列三、多线程下使用哈希表 前言 在数据结构中&#xff0c;我们学习过 Java 的内置集合&#xff0c;但是我们知道&#xff0c;我们学过的大多数集合类都是线程不安全的&#xff0c;少数如 Vector&#xff0c;Stack…