Redis基本类型学习之Sorted Set (2)

2024-08-22 16:48

本文主要是介绍Redis基本类型学习之Sorted Set (2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

你必须非常努力,才能看起来毫不费力!

微信搜索公众号[ 漫漫Coding路 ],一起From Zero To Hero !

前言

在上篇文章中,我们学习了Redis Sorted Set的基本概念和部分命令。这部分命令较多,预计还需要两篇文章才能学完,每篇文章在10个命令左右。对于这些命令,不需要全部记住,只需要自己动手操作过一遍,有个印象。在真正需要使用时,能够想到有这种操作,然后再去查阅命令即可。

ZINCRBY

可用版本:>= 1.2.0

时间复杂度: O(log(N)) ,N为有序数组中的元素个数

命令格式

ZINCRBY key increment member

命令描述

  • 将有序数组中member对应的score值,加上increment
  • 如果有序数组中不存在这个member元素,那么就新增这个元素,别设置score值为increment
  • 如果有序数组不存在,新建有序数组,并添加这个元素;
  • score值可以是整数值或双精度浮点数,也可以是负数,相当于减;
  • 如果key对应的数据类型不是有序数组,返回error;

返回值

字符串:member对应的新score值

示例

127.0.0.1:6379> zadd myzset 1 one
(integer) 1# 加1
127.0.0.1:6379> zincrby myzset 1 one
"2"# 减2
127.0.0.1:6379> zincrby myzset -2 one
"0"# 查看分值
127.0.0.1:6379> zscore myzset one
"0"

ZRANK

可用版本:>= 2.0.0

时间复杂度: O(log(N)) ,N为有序数组中的元素个数

命令格式

ZRANK key member

命令描述

  • 按照分值从低到高的顺序,返回元素在有序数组中的排名;
  • 排名(索引)从0开始,也就是分值最低的元素排名为0

返回值

整数:如果member在有序集合中,返回排名

nil:有序数组不存在或者member不存在,返回nil

示例

127.0.0.1:6379> zadd myzset 1 one
(integer) 1
127.0.0.1:6379> zadd myzset 2 two
(integer) 1# 查看排名
127.0.0.1:6379> zrank myzset one
(integer) 0
127.0.0.1:6379> zrank myzset two
(integer) 1

ZREVRANK

可用版本:>= 2.0.0

时间复杂度: O(log(N)) ,N为有序数组中的元素个数

命令格式

ZREVRANK key member

命令描述

  • ZRANK相反,ZREVRANK按照分值从高到低的顺序,返回元素在有序数组中的排名;
  • 排名(索引)从0开始,分值最高的元素排名为0

返回值

整数:如果member在有序集合中,返回排名

nil:有序数组不存在或者member不存在,返回nil

示例

127.0.0.1:6379> zadd myzset 1 one
(integer) 1
127.0.0.1:6379> zadd myzset 2 two
(integer) 1# 查看排名
127.0.0.1:6379> zrevrank myzset one
(integer) 1
127.0.0.1:6379> zrevrank myzset two
(integer) 0

ZREM

可用版本:>= 2.0.0

时间复杂度: O(M*log(N)),N为有序数组中的元素个数,M为命令提供的元素个数

命令变化

自2.4版本后,可以删除多个元素

命令格式

ZREM key member [member ...]

命令描述

  • 从有序数组中,移除指定的元素
  • 如果元素不存在,忽略该元素
  • 如果key存在,但是对应的类型不是有序集合,返回error

返回值

整数:被移除的元素个数(不包含不存在的元素)

示例

127.0.0.1:6379> zadd myzset 1 one
(integer) 1
127.0.0.1:6379> zadd myzset 2 two
(integer) 1
127.0.0.1:6379> zadd myzset 3 three
(integer) 1# 删除两个存在的,和一个不存在的元素
127.0.0.1:6379> zrem myzset one two notexists
(integer) 2# 遍历集合
127.0.0.1:6379> zrange myzset 0 -1
1) "three"

ZREMRANGEBYRANK

可用版本:>= 2.0.0

时间复杂度: O(M+log(N)),N为有序数组中的元素个数,M为要删除的元素个数

命令格式

ZREMRANGEBYRANK key start stop

命令描述

  • 移除有序数组中,排序位于startstop之间的元素;
  • startstop为正数索引时,都是从0开始,0表示分值最小的第一个元素,1为第二个元素,以此类推;
  • 如果startstop为负数,-1表示分值最大的最后一个元素,-2表示倒数第二个元素,以此类推;

返回值

整数:被移除的元素个数

示例

127.0.0.1:6379> zadd myzset 1 one
(integer) 1
127.0.0.1:6379> zadd myzset 2 two
(integer) 1
127.0.0.1:6379> zadd myzset 3 three
(integer) 1# 移除第二个和第三个元素(索引为1 和 2)
127.0.0.1:6379> zremrangebyrank myzset 1 2
(integer) 2
127.0.0.1:6379> zrange myzset 0 -1
1) "one"

ZREMRANGEBYSCORE

可用版本:>= 1.2.0

时间复杂度: O(M+log(N)),N为有序数组中的元素个数,M为要删除的元素个数

命令格式

ZREMRANGEBYSCORE key min max

命令描述

  • 移除有序数组中,score值介于 minmax之间的元素,默认为闭区间[min,max];
  • -inf+inf也是合法输入,表示负无穷和正无穷
  • 如果想要使用开区间,可以在minmax前加一个’(
  • 区间取值问题可以参考上一篇的 ZRANGEBYSCORE

返回值

整数:被移除的元素个数

示例

127.0.0.1:6379> zadd myzset 1 one
(integer) 1
127.0.0.1:6379> zadd myzset 2 two
(integer) 1
127.0.0.1:6379> zadd myzset 3 three
(integer) 1
127.0.0.1:6379> zadd myzset 4 four
(integer) 1# 删除分值[1,2]之间的元素
127.0.0.1:6379> zremrangebyscore myzset 1 2
(integer) 2# 删除负无穷到4(开区间)之间的元素
127.0.0.1:6379> zremrangebyscore myzset -inf (4
(integer) 1
127.0.0.1:6379> zrange myzset 0 -1
1) "four"

ZREMRANGEBYLEX

可用版本:>= 2.8.9

时间复杂度: O(M+log(N)),N为有序数组中的元素个数,M为要删除的元素个数

命令格式

ZREMRANGEBYLEX key min max

命令描述

  • 当有序集合中所有元素的score值都一样时,使用字符串字典序排序,删除 minmax之间的元素
  • 此处的min、max,与上篇文章中的ZRANGEBYLEX 概念相同
  • 如果使用相同的minmaxZREMRANGEBYLEX删除的元素和ZREMRANGEBYLEX返回的元素相同

返回值

整数:被移除的元素个数

示例

127.0.0.1:6379> ZADD myzset 0 aaaa 0 b 0 c 0 d 0 e
(integer) 5
127.0.0.1:6379> ZADD myzset 0 foo 0 zap 0 zip 0 ALPHA 0 alpha
(integer) 5
127.0.0.1:6379> ZRANGE myzset 0 -11) "ALPHA"2) "aaaa"3) "alpha"4) "b"5) "c"6) "d"7) "e"8) "foo"9) "zap"
10) "zip"# 删除元素
127.0.0.1:6379> ZREMRANGEBYLEX myzset [alpha [omega
(integer) 6127.0.0.1:6379> ZRANGE myzset 0 -1
1) "ALPHA"
2) "aaaa"
3) "zap"

ZLEXCOUNT

可用版本:>= 2.8.9

时间复杂度: O(log(N)),N为有序数组中的元素个数

命令格式

ZLEXCOUNT key min max

命令描述

  • 当有序集合中所有元素的score值都一样时,返回字符串字典序排序后 minmax之间的元素
  • 此处的min、max,与上篇文章中的ZRANGEBYLEX 概念相同

返回值

整数:字典序范围内的元素个数

示例

127.0.0.1:6379> ZADD myzset 0 a 0 b 0 c 0 d 0 e
(integer) 5
127.0.0.1:6379> ZADD myzset 0 f 0 g
(integer) 2# 全部区间
127.0.0.1:6379> ZLEXCOUNT myzset - +
(integer) 7# [b,f]区间
127.0.0.1:6379> ZLEXCOUNT myzset [b [f
(integer) 5

ZPOPMAX

可用版本:>= 5.0.0

时间复杂度: O(log(N)*M),N为有序数组中的元素个数,M为弹出的元素个数

命令格式

ZPOPMAX key [count]

命令描述

  • 移除并返回前countscore较高的元素
  • 如果不指定count值,默认为1
  • 如果count超过集合长度,不会报错
  • 返回结果中,分值最大的元素在第一个,同时会带有分值

返回值

列表:元素列表及其分值

示例

127.0.0.1:6379> ZADD myzset 1 "one"
(integer) 1
127.0.0.1:6379> ZADD myzset 2 "two"
(integer) 1
127.0.0.1:6379> ZADD myzset 3 "three"
(integer) 1# 默认返回1个
127.0.0.1:6379> ZPOPMAX myzset
1) "three"
2) "3"# 超过列表长度时,返回所有元素
127.0.0.1:6379> ZPOPMAX myzset 3
1) "two"
2) "2"
3) "one"
4) "1"

ZPOPMIN

可用版本:>= 5.0.0

时间复杂度: O(log(N)*M),N为有序数组中的元素个数,M为弹出的元素个数

命令格式

ZPOPMIN key [count]

命令描述

  • 移除并返回前countscore的元素
  • 如果不指定count值,默认为1
  • 如果count超过集合长度,不会报错
  • 返回结果中,分值最小的元素在第一个,同时会带有分值

返回值

列表:元素列表及其分值

示例

127.0.0.1:6379> ZADD myzset 1 "one"
(integer) 1
127.0.0.1:6379> ZADD myzset 2 "two"
(integer) 1
127.0.0.1:6379> ZADD myzset 3 "three"
(integer) 1# 默认返回1个
127.0.0.1:6379> zpopmin myzset
1) "one"
2) "1"# 超过列表长度时,返回所有元素
127.0.0.1:6379> zpopmin myzset 3
1) "two"
2) "2"
3) "three"
4) "3"

ZMSCORE

可用版本:>= 6.2.0

时间复杂度: O(N),N为命令提供的元素个数

命令格式

ZMSCORE key member [member ...]

命令描述

  • 返回多个元素对应的分值
  • 如果该元素在有序数组中不存在,返回nil

返回值

数组:提供的所有元素对应的分值列表

示例

127.0.0.1:6379> ZADD myzset 1 "one"
(integer) 1
127.0.0.1:6379> ZADD myzset 2 "two"
(integer) 1
127.0.0.1:6379> ZMSCORE myzset "one" "two" "nofield"
1) "1"
2) "2"
3) (nil)

总结

本文介绍了有序集合中的部分相关命令,包括

  • ZINCRBY:元素score加上一个值
  • ZRANK、ZREVRANK:获取元素在有序数组中的排名
  • ZREM:删除元素
  • ZREMRANGEBYRANK、ZREMRANGEBYSCORE、ZREMRANGEBYLEX:删除给定区间的元素
  • ZLEXCOUNT:返回指定字典序内的元素个数
  • ZPOPMAX、ZPOPMIN:移除首/尾前count个元素
  • ZMSCORE:返回多个元素的分值

更多

个人博客: https://lifelmy.github.io/

微信公众号:漫漫Coding路

这篇关于Redis基本类型学习之Sorted Set (2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis延迟队列的实现示例

《Redis延迟队列的实现示例》Redis延迟队列是一种使用Redis实现的消息队列,本文主要介绍了Redis延迟队列的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、什么是 Redis 延迟队列二、实现原理三、Java 代码示例四、注意事项五、使用 Redi

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

redis-cli命令行工具的使用小结

《redis-cli命令行工具的使用小结》redis-cli是Redis的命令行客户端,支持多种参数用于连接、操作和管理Redis数据库,本文给大家介绍redis-cli命令行工具的使用小结,感兴趣的... 目录基本连接参数基本连接方式连接远程服务器带密码连接操作与格式参数-r参数重复执行命令-i参数指定命

深入理解Redis大key的危害及解决方案

《深入理解Redis大key的危害及解决方案》本文主要介绍了深入理解Redis大key的危害及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、背景二、什么是大key三、大key评价标准四、大key 产生的原因与场景五、大key影响与危

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

Redis过期键删除策略解读

《Redis过期键删除策略解读》Redis通过惰性删除策略和定期删除策略来管理过期键,惰性删除策略在键被访问时检查是否过期并删除,节省CPU开销但可能导致过期键滞留,定期删除策略定期扫描并删除过期键,... 目录1.Redis使用两种不同的策略来删除过期键,分别是惰性删除策略和定期删除策略1.1惰性删除策略

Linux(Centos7)安装Mysql/Redis/MinIO方式

《Linux(Centos7)安装Mysql/Redis/MinIO方式》文章总结:介绍了如何安装MySQL和Redis,以及如何配置它们为开机自启,还详细讲解了如何安装MinIO,包括配置Syste... 目录安装mysql安装Redis安装MinIO总结安装Mysql安装Redis搜索Red