redis之(八)redis的有序集合类型的命令

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: [一]增加元素 --->命令:ZADD key score member [score member] --->向有序集合放入一个分数为score的member元素 --->元素存在,则用新分数更换旧分数。
[一]增加元素
--->命令:ZADD key score member [score member]
--->向有序集合放入一个分数为score的member元素
--->元素存在,则用新分数更换旧分数。
--->命令返回新加入集合的元素,不包含之前已经存在的元素
--->分数不仅可以是整数,也可以是浮点数
--->+inf  -inf 表示正无穷和负无穷
 
 
[二]获得元素的分数
--->命令:ZSCORE key member
--->获得元素所关联的分数
 
 
[三]获得排名在某个范围内的元素的列表
--->命令:ZRANGE key start stop [WITHSCORES]
--->zrange 命令会按照元素分数从小到大的顺序返回索引从start到stop之间的所有元素(双闭区间)
--->如果获取元素列表的同时,还想获取元素对应的分数,在命令的最后加上withscores参数
--->索引从0开始。从左往右。-1表示右边第一个元素。[0,-1]表示返回所有元素
--->zrange命令的时间复杂度为O(log n+m),n为有序集合的基数,m为返回元素的个数
---> 如果两个元素的分数相等,redis会按(0-9,a-z,A-Z)顺序排序,
 
[四]获得排名在某个范围内的元素的列表
--->命令:ZREVRANGE key start stop [WITHSCORES]
--->命令会按照元素分数从大到小的顺序返回索引从start到stop之间的所有元素(双闭区间)
 
[五]获得指定分数范围的元素
--->命令:ZRANGEBYSCORE key min  max [WITHSCORES] [LIMIT offset count]
--->按从小到大的分数返回在min和max间(双闭区间)的元素
--->如果希望返回的元素,不包含两端点的值,则在分数前加“(”。
--->min max还支持无穷大。+inf正无穷  -inf负无穷
--->withscores标示返回元素列表的同时,还要返回分数
--->limit 从offset索引开始的count个人
[六]增加某个元素的分数
--->命令:ZINCRBY key increment  member
--->使key键里member元素的分数在原有基础上增加increment分数。
--->分数可以是正数,也可以是负数
--->返回值是增加后的分数。
 
[七]获得集合中元素的数量
--->命令:ZCARD key
--->获取key键集合中元素的数量
 
[八]获取指定分数范围内元素的个数
--->命令:ZCOUNT key min max
--->min max的取值规则和ZRANGEBYSCORE一样
 
[九]删除一个或多个元素
--->命令:ZREM key member [member...]
--->返回值是删除成功的元素。不存在的元素,不包括在内
 
[十]按照排名范围删除元素
--->命令:ZREMRANGEBYRANK key start stop
--->按照分数从小到大的顺序删除在指定排名范围内的所有元素,并返回删除的元素数量
 
[十一]按照分数范围删除元素
--->命令:ZREMRANGEBYSCORE key min max
--->按照分数从小到大的区间删除元素,并返回删除成功的元素个数
 
[十二]获得元素的排名
--->命令:ZRANK key member
--->按照分数从小到大的顺序,获得元素的排名。分数最小的元素排名0
--->命令:ZREVRANK key member
--->按照分数从大到小的顺序,拍的元素的排名。分数最大的元素排名0
 
[十三]计算有序集合的交集
--->命令:ZINTERSTORE destination numkeys key[ key ...] [WEIGHTS weight[weight ...]] [AGGERGATE SUM|MIN|MAX]
--->用来计算多个有序集合的交集,并将结果存储在destination键中(同样是按有序集合进行存储),返回的是destination中存储元素的个数
--->destination有序集合中元素的分数,是由参数AGGERGATE决定的。
(1)当AGGERGATE是sum的时候(也是默认值),destination键中元素的分数是每个参与计算的集合中该元素的分数之和
(2)当AGGERGATE是min的时候destination键中元素的分数是每个参与计算的集合中该元素的分数最小值
(3)当AGGERGATE是max的时候destination键中元素的分数是每个参与计算的集合中该元素的分数最大值
--->该命令还能够通过weights设置每个集合的权重,每个集合在参与计算时元素的分数会被乘上该集合的权重。
--->ZINTERSTORE是计算交集的。与该命令类似的还有:ZUNIONSTORE是计算集合并集的。
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1月前
|
存储 消息中间件 NoSQL
Redis数据结构:List类型全面解析
Redis数据结构——List类型全面解析:存储多个有序的字符串,列表中每个字符串成为元素 Eelement,最多可以存储 2^32-1 个元素。可对列表两端插入(push)和弹出(pop)、获取指定范围的元素列表等,常见命令。 底层数据结构:3.2版本之前,底层采用**压缩链表ZipList**和**双向链表LinkedList**;3.2版本之后,底层数据结构为**快速链表QuickList** 列表是一种比较灵活的数据结构,可以充当栈、队列、阻塞队列,在实际开发中有很多应用场景。
|
2月前
|
存储 NoSQL 关系型数据库
Redis 有序集合(sorted set)
10月更文挑战第17天
84 4
|
2月前
|
消息中间件 存储 监控
redis 的List类型 实现 排行榜
【10月更文挑战第8天】
42 2
|
2月前
|
存储 NoSQL Redis
redis-set类型
【10月更文挑战第6天】
47 1
|
1月前
|
存储 NoSQL Java
Redis命令:列表模糊删除详解
通过本文的介绍,我们详细探讨了如何在Redis中实现列表的模糊删除。虽然Redis没有直接提供模糊删除命令,但可以通过组合使用 `LRANGE`和 `LREM`命令,并在客户端代码中进行模糊匹配,来实现这一功能。希望本文能帮助你在实际应用中更有效地操作Redis列表。
54 0
|
2月前
|
缓存 NoSQL 测试技术
Redis如何解决频繁的命令往返造成的性能瓶颈!
Redis如何解决频繁的命令往返造成的性能瓶颈!
|
2月前
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
29 3
|
2月前
|
消息中间件 分布式计算 NoSQL
大数据-41 Redis 类型集合(2) bitmap位操作 geohash空间计算 stream持久化消息队列 Z阶曲线 Base32编码
大数据-41 Redis 类型集合(2) bitmap位操作 geohash空间计算 stream持久化消息队列 Z阶曲线 Base32编码
29 2
|
2月前
|
缓存 NoSQL Redis
Redis命令:列表模糊删除详解
Redis命令:列表模糊删除详解
76 3
|
1月前
|
存储 NoSQL 关系型数据库
Redis的ZSet底层数据结构,ZSet类型全面解析
Redis的ZSet底层数据结构,ZSet类型全面解析;应用场景、底层结构、常用命令;压缩列表ZipList、跳表SkipList;B+树与跳表对比,MySQL为什么使用B+树;ZSet为什么用跳表,而不是B+树、红黑树、二叉树