[Redis]Zset类型

2024-06-05 07:04
文章标签 类型 redis zset

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

Zset有序集合相对于字符串、列表、哈希、集合来说会有一些陌生。

它保留了集合不能有重复成员的特点,但与集合不同的是,有序集合中的每个元素都有一个唯一的浮点类型的分数(score)与之关联,着使得有序集合中的元素是可以维护有序性的,但这个有序不是用下标作为排序依据而是用这个分数。

有序集合中的元素是不能重复的,但分数允许重复。类比于一次考试之后,每个人一定有一个唯一的分数,但分数允许相同

基本命令

zadd命令

添加或者更新指定的元素以及关联的分数到 zset 中,分数应该符合 double 类型,+inf/-inf 作为正负极限也是合法的

返回值:本次添加成功的元素个数

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

XX:仅仅用于更新已经存在的元素,不会添加新元素。

NX:仅用于添加新元素,不会更新已经存在的元素。

CH:默认情况下,ZADD 返回的是本次添加的元素个数,但指定这个选项之后,就会还包含本次更新的元素的个数。

INCR:此时命令类似 ZINCRBY 的效果,将元素的分数加上指定的分数。此时只能指定一个元素和分数 

(添加了三个元素,aaa分数是10,bbb分数是5,ccc分数是15。因为zset是按分数有序的,所以输出的时候按从大到小输出) 

zcard命令

获取一个 zset 的基数(cardinality),即 zset 中的元素个数

返回值:zset 内的元素个数

zcard key

zscore命令

返回指定元素的分数

返回值:分数

zscore key member 

zrem命令

删除指定的元素

返回值:本次操作删除的元素个数

zrem key member [member ...] 

 

zcount命令

返回分数在 min 和 max 之间的元素个数,默认情况下,min 和 max 都是包含的,可以通过 ( 排除

返回值:满足条件的元素列表个数

zcount key min max

 zcount key 5 10 ,就是说取分数为[5,10]区间的元素

zcount key (5 15 ,就是说取分数为(5,15]区间的元素

zcount key (5 10 ,就是说取分数为(5,10]区间的元素

 zrange命令

返回指定区间里的元素,分数按照升序。带上 WITHSCORES 可以把分数也返回。

返回值:区间内的元素列表

zrange key start stop [WITHSCORES]

此处的 [start, stop] 为下标构成的区间. 从 0 开始, 支持负数.

 

zrevrange命令

返回指定区间里的元素,分数按照降序。带上 WITHSCORES 可以把分数也返回。

这个命令可能在 6.2.0 之后废弃,并且功能合并到 ZRANGE 中。

返回值:区间内的元素列表

zrevrang key start stop [WITHSCORES]

 

 

 zrangebyscore命令

返回分数在 min 和 max 之间的元素,默认情况下,min 和 max 都是包含的,可以通过 ( 排除

返回值:区间内的元素列表

zrangebyscore key min max [WITHSCORES]

 

zrangebyscore key 10 15         表示找分数为[10,15]区间内的所用元素

zrangebyscore key (10 15         表示找分数为[10,15]区间内的所有元素

zpopmax命令

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

返回值:分数和元素列表 

zpopmax key [count]

zpopmin命令

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

返回值:分数和元素列表

zpopmin key [count] 

 

bzpopmax命令

zpopmax 的阻塞版本

返回值:元素列表

bzpopmax key [key ...] timeout

bzpopmin命令

zpopmin 的阻塞版本

返回值:元素列表

bzpopmin key [key ...] timeout

 

 首先用bzpopmin阻塞等待key的一个最小值

 

 起另一个客户端,向数据库插入三个值

原客户端返回key的最小一个值

 这时候只剩两个值

zrank命令

返回指定元素的排名,升序

返回值:排名

zrank key member

 

zrevrank命令

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

返回值:排名

zrevrank key member 

 

zremrangebyrank命令

按照排序,升序删除指定范围的元素,左闭右闭

返回值:本次操作删除的元素个数

zremrangebyrank key start stop

 

zremrangebyscore命令

按照分数删除指定范围的元素,左闭右闭

返回值:本次操作删除的元素个数

zremrangebyscore key min max

 

 zincrby命令

为指定的元素的关联分数添加指定的分数值

返回值:增加后元素的分数

 (zincrby key 100 aaa 就是给key里的aaa的分数加100)

集合间操作

zinterstore命令

求出给定有序集合中元素的交集并保存进目标有序集合中,在合并过程中以元素为单位进行合并,元素对应的分数按照不同的聚合方式和权重得到新的分数

返回值:目标集合中的元素个数

 zinterstore destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE ]

 

zinterstore key3 2 key1 key2 weights 2 3

表示结果放进key3,有2个key要操作,key1和key2,

结果有aaa和bbb

如果加了weights选项,代表加权重,也就是倍率,比如这个就是key1*2 和 key2 *3 

那么操作之后,key1 就是 1*2 + 300 * 3 = 902;key2就是2 * 2 + 400 * 3 = 1204

zunionstore命令

求出给定有序集合中元素的并集并保存进目标有序集合中,在合并过程中以元素为单位进行合并,元素对应的分数按照不同的聚合方式和权重得到新的分数

返回值:⽬标集合中的元素个数

zunionstore destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE ]

 

内部编码

有序集合类型的内部编码有两种:

• ziplist(压缩列表):当有序集合的元素个数⼩于 zset-max-ziplist-entries 配置(默认 128 个), 同时每个元素的值都小于 zset-max-ziplist-value 配置(默认 64 字节)时,Redis 会用 ziplist 来作为有序集合的内部实现,ziplist 可以有效减少内存的使⽤。

• skiplist(跳表):当 ziplist 条件不满足时,有序集合会使用 skiplist 作为内部实现,因为此时 ziplist 的操作效率会下降。

1)当元素个数较少且每个元素较小时,内部编码为 ziplist:

2)当元素个数超过 128 个,内部编码 skiplist:

3)当某个元素大于 64 字节时,内部编码 skiplist:

使用场景

有序集合比较典型的使用场景就是排行榜系统。例如常见的网站上的热榜信息,榜单的维度可能 是多方面的:按照时间、按照阅读量、按照点赞量。本例中我们使用点赞数这个维度,维护每天的热榜:

1)添加用户赞数

例如用户 james 发布了一篇文章,并获得 3 个赞,可以使用有序集合的 zadd 和 zincrby 功能:

zadd user:ranking:2022-03-15 3 james

之后如果再获得赞,可以使用 zincrby:

zincrby user:ranking:2022-03-15 1 james

2)取消用户赞数

由于各种原因(例如用户注销、用户作弊等)需要将用户删除,此时需要将用户从榜单中删除掉,可以使用 zrem。例如删除成员 tom:

zrem user:ranking:2022-03-15 tom

3)展示获取赞数最多的 10 个用户

zrevrangebyrank user:ranking:2022-03-15 0 9

这篇关于[Redis]Zset类型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Redis分片集群的实现

《Redis分片集群的实现》Redis分片集群是一种将Redis数据库分散到多个节点上的方式,以提供更高的性能和可伸缩性,本文主要介绍了Redis分片集群的实现,具有一定的参考价值,感兴趣的可以了解一... 目录1. Redis Cluster的核心概念哈希槽(Hash Slots)主从复制与故障转移2.

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S

redis+lua实现分布式限流的示例

《redis+lua实现分布式限流的示例》本文主要介绍了redis+lua实现分布式限流的示例,可以实现复杂的限流逻辑,如滑动窗口限流,并且避免了多步操作导致的并发问题,具有一定的参考价值,感兴趣的可... 目录为什么使用Redis+Lua实现分布式限流使用ZSET也可以实现限流,为什么选择lua的方式实现

Redis中管道操作pipeline的实现

《Redis中管道操作pipeline的实现》RedisPipeline是一种优化客户端与服务器通信的技术,通过批量发送和接收命令减少网络往返次数,提高命令执行效率,本文就来介绍一下Redis中管道操... 目录什么是pipeline场景一:我要向Redis新增大批量的数据分批处理事务( MULTI/EXE

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

Redis中的常用的五种数据类型详解

《Redis中的常用的五种数据类型详解》:本文主要介绍Redis中的常用的五种数据类型详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Redis常用的五种数据类型一、字符串(String)简介常用命令应用场景二、哈希(Hash)简介常用命令应用场景三、列表(L