零基础学习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

相关文章

PHP执行php.exe -v命令报错的解决方案

《PHP执行php.exe-v命令报错的解决方案》:本文主要介绍PHP执行php.exe-v命令报错的解决方案,文中通过图文讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录执行phpandroid.exe -v命令报错解决方案执行php.exe -v命令报错-PHP War

Python使用pysmb库访问Windows共享文件夹的详细教程

《Python使用pysmb库访问Windows共享文件夹的详细教程》本教程旨在帮助您使用pysmb库,通过SMB(ServerMessageBlock)协议,轻松连接到Windows共享文件夹,并列... 目录前置条件步骤一:导入必要的模块步骤二:配置连接参数步骤三:实例化SMB连接对象并尝试连接步骤四:

使用Java编写一个文件批量重命名工具

《使用Java编写一个文件批量重命名工具》这篇文章主要为大家详细介绍了如何使用Java编写一个文件批量重命名工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录背景处理1. 文件夹检查与遍历2. 批量重命名3. 输出配置代码片段完整代码背景在开发移动应用时,UI设计通常会提供不

Linux使用粘滞位 (t-bit)共享文件的方法教程

《Linux使用粘滞位(t-bit)共享文件的方法教程》在Linux系统中,共享文件是日常管理和协作中的常见任务,而粘滞位(StickyBit或t-bit)是实现共享目录安全性的重要工具之一,本文将... 目录文件共享的常见场景基础概念linux 文件权限粘滞位 (Sticky Bit)设置共享目录并配置粘

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

CentOS系统使用yum命令报错问题及解决

《CentOS系统使用yum命令报错问题及解决》文章主要讲述了在CentOS系统中使用yum命令时遇到的错误,并提供了个人解决方法,希望对大家有所帮助,并鼓励大家支持脚本之家... 目录Centos系统使用yum命令报错找到文件替换源文件为总结CentOS系统使用yum命令报错http://www.cppc

使用@Slf4j注解,log.info()无法使用问题

《使用@Slf4j注解,log.info()无法使用问题》在使用Lombok的@Slf4j注解打印日志时遇到问题,通过降低Lombok版本(从1.18.x降至1.16.10)解决了问题... 目录@Slf4androidj注解,log.info()无法使用问题最后解决总结@Slf4j注解,log.info(

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取