Redis底层学习(六)—存储类型-ZSet篇

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Redis底层学习(六)—存储类型-ZSet篇

结构特点

适⽤场景:存储不重复且有序需求的数据,⽐如:学⽣的⾼考成绩。

它的内部采⽤“ 跳跃列表 ”实现,根据score进⾏排序

具体服务器操作命令

添加元素到zset中: ZADD [key] [score1] [member1] … [scoreN][memberN]

查看zset中某个元素的score值: ZSCORE [key] [member]

升序输出: ZRANGE [key] 0 -1 输出从下标0到下标-1(即倒数第⼀个)中的所有元素从⼩到

升序输出: ZRANGEBYSCORE [key] -inf +inf 与上⾯输出效果⼀样,输出score>=负⽆

穷,score<=正⽆穷的所有元素

降序输出: ZREVRANGE [key] 0 -1

根据某些score条件,升序展示zset中的元素: ZRANGEBYSCORE [key] [minScore] [maxS

core]

根据某些score条件,降序展示zset中的元素: ZREVRANGEBYSCORE [key] [maxScore] [m

inScore]

查看zset中的元素个数: ZCARD [key]

删除zset中的某个元素: ZREM key [member1] … [memberN]

底层结构

有序集合编码的内部实现可以是 ziplist 或 skiplist

zipList 压缩链表:

每个集合元素使⽤两个紧挨在⼀起的压缩列表节点来保存,第⼀个节点保存元素的成员( member ),⽽第⼆个节点则保存元素的分值( score )。压缩列表内的集合元素按分值( score )从⼩到⼤进⾏排序。

skiplist:

skiplist 编码的有序集合采⽤ zset 结构作为底层实现,⼀个zset同时包含⼀个字

典 dict 和⼀个跳跃表 zskiplist 。

当有序集合对象可以同时满⾜以下两个条件时,使⽤ ziplist 编码,否则使

⽤ skiplist 编码:

有序集合保存的元素数量⼩于等于128个

有序集合保存的所有元素成员的⻓度都⼩于64字节

应用场景

对点赞用户进行排序操作


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
3月前
|
消息中间件 存储 负载均衡
Redis使用ZSET实现消息队列使用总结二
Redis使用ZSET实现消息队列使用总结二
60 0
|
4月前
|
存储 NoSQL Redis
Redis系列学习文章分享---第十六篇(Redis原理1篇--Redis数据结构-动态字符串,insert,Dict,ZipList,QuickList,SkipList,RedisObject)
Redis系列学习文章分享---第十六篇(Redis原理1篇--Redis数据结构-动态字符串,insert,Dict,ZipList,QuickList,SkipList,RedisObject)
75 1
|
4月前
|
NoSQL Java Redis
Redis系列学习文章分享---第十八篇(Redis原理篇--网络模型,通讯协议,内存回收)
Redis系列学习文章分享---第十八篇(Redis原理篇--网络模型,通讯协议,内存回收)
69 0
|
4月前
|
存储 消息中间件 缓存
Redis系列学习文章分享---第十七篇(Redis原理篇--数据结构,网络模型)
Redis系列学习文章分享---第十七篇(Redis原理篇--数据结构,网络模型)
80 0
|
5天前
|
存储 NoSQL API
7)深度解密 Redis 的有序集合(ZSet)
7)深度解密 Redis 的有序集合(ZSet)
9 0
|
2月前
|
存储 NoSQL 算法
深入理解Redis数据类型Zset原理
本文深入探讨了Redis中的Zset(有序集合)数据类型,它是一种可以存储排序功能的集合,其中每个元素都具有一个浮点型的score属性,用于根据score进行排序。
深入理解Redis数据类型Zset原理
|
2月前
|
存储 NoSQL 算法
Redis6入门到实战------ 三、常用五大数据类型(列表(List)、集合(Set)、哈希(Hash)、Zset(sorted set))
这是关于Redis 6入门到实战的文章,具体内容涉及Redis的五大数据类型:列表(List)、集合(Set)、哈希(Hash)、有序集合(Zset(sorted set))。文章详细介绍了这些数据类型的特点、常用命令以及它们背后的数据结构。如果您有任何关于Redis的具体问题或需要进一步的帮助,请随时告诉我。
|
2月前
|
缓存 NoSQL 关系型数据库
Redis学习总结
Redis学习总结
33 1
|
3月前
|
NoSQL Redis 索引
Redis 中ZSET数据类型命令使用及对应场景总结
Redis 中ZSET数据类型命令使用及对应场景总结
49 2
|
3月前
|
消息中间件 存储 NoSQL
Redis使用ZSET实现消息队列使用总结一
Redis使用ZSET实现消息队列使用总结一
70 0
下一篇
无影云桌面