图解Redis 05 | Zset数据类型的原理及应用场景
创作时间:
作者:
@小白创作中心
图解Redis 05 | Zset数据类型的原理及应用场景
引用
CSDN
1.
https://m.blog.csdn.net/weixin_42627385/article/details/143318224
Redis的Zset数据类型是一种有序集合,每个元素都有一个分数用于排序。这种数据结构在实现排行榜等需要频繁更新和排序的场景中非常有用。本文将详细介绍Zset的原理、实现方式以及具体应用场景。
介绍
Zset 类型(有序集合)与 Set 类型相比,增加了一个排序属性 score。对于有序集合 Zset,每个元素由两个部分组成:一个是元素的值,另一个是用于排序的分数 score。
有序集合继承了Set中成员唯一(元素值不能重复,分数可以重复)的特性,但不同之处在于,有序集合中的元素是按分数进行排序的。
内部实现
Zset 类型的底层数据结构可以采用ziplist或skiplist来实现:
- 当有序集合中的元素个数少于 128 个,并且每个元素的值小于 64 字节时,Redis 会使用ziplist作为 Zset 的底层数据结构。
- 如果不满足这些条件,Redis 则会使用skiplist来实现 Zset 的底层数据结构。
要注意的是,从 Redis 7.0 开始,压缩列表已被废弃,改用更高效的 listpack 数据结构来实现。
常用命令
添加一个或多个元素
zadd key [NX|XX] [CH] [INCR] score member [score member …]
# NX:仅当成员不存在时才添加。如果成员已经存在,什么都不做。
# CH:返回被成功修改的成员数,新增的成员和更新了分数的成员都将被计数。
# INCR:将给定分数递增到成员的当前分数上。如果成员不存在,ZADD 会像正常一样创建一个成员,并将分数设置为指定的值。
> zadd zset1 10 Java
(integer) 1
> zadd zset1 4 Golang 5 JavaScript 7 Python
(integer) 3
查询所有元素
zrange key start stop [WITHSCORES]
> zrange zset1 0 -1
1) "Golang"
2) "JavaScript"
3) "Python"
4) "Java"
其中,-1表示最后一个元素,查询结果包括开始和结束元素。
删除一个或多个元素(根据元素值)
zrem key member [member …]
> zrem zset1 Java Python
2
> zrange zset1 0 -1
1) "Golang"
2) "JavaScript"
在删除操作中,如果包含的元素不存在,该命令仍会正常执行;所有不存在的元素将被自动忽略。
查询某个元素的分数值
zscore key member
> zscore zset1 Golang
4.0
查询指定分数区间的元素
zrangebyscore key min max [WITHSCORES] [LIMIT offset count]
> zrangebyscore zset1 3 7
1) "Golang"
2) "JavaScript"
查询元素的排名
zrank key member
> zadd zset1 10 C++ 12 Ruby
(integer) 2
> zrank zset1 C++
2
> zrank zset1 Golang
0
可以看出排名都是从0开始的,排名可以理解为元素排序后的下标值。更多操作命令请参见文末部分。
应用场景
在需要展示最新榜单或排行榜的场景下,如果数据更新频繁或需要分页显示,建议优先使用 Zset(有序集合)。
排行榜
有序集合最典型的使用场景就是排行榜,例如学生成绩排行、游戏积分排行、视频播放排行、电商系统中产品销量排行等。
以文章点赞量排行为例,假设我发表了 3 篇文章,分别获得了 200、50 和 100 个点赞。
- arcticle:1 获得200个赞
> ZADD arcticle:ranking 200 arcticle:1
(integer) 1
- arcticle:2获得50个赞
> ZADD arcticle:ranking 50 arcticle:2
(integer) 1
- arcticle:3获得100个赞
> ZADD arcticle:ranking 100 arcticle:3
(integer) 1
- article:2又加了一个赞
> ZINCRBY arcticle:ranking 1 arcticle:2
51.0
- 查看某篇文章的点赞数
> ZSCORE arcticle:ranking arcticle:3
100.0
- 获取点赞数最多的2篇文章,
ZREVRANGE arcticle:ranking 0 1 WITHSCORES
1) "arcticle:1"
2) 200.0
3) "arcticle:3"
4) 100.0
- 获取点赞数在50~100的文章
ZRANGEBYSCORE arcticle:ranking 100 200 WITHSCORES
1) "arcticle:3"
2) 100.0
3) "arcticle:1"
4) 200.0
更多有序集合命令
1.查询有序集合的元素个数。
zcard key
> zcard arcticle:ranking
3
- 查询某个元素的逆序排名(从高到低的排名)。
zrevrank key member
> zrevrank arcticle:ranking arcticle:2
2
> zrange arcticle:ranking 0 -1
1) "arcticle:2"
2) "arcticle:3"
3) "arcticle:1"
- 删除指定排名范围内的元素
zremrangebyrank key start stop
> zremrangebyrank arcticle:ranking 0 1 #Delete element
(integer) 2
> zrange arcticle:ranking 0 -1 #Query all elements
1) "arcticle:1"
- 删除指定分数范围内的元素。
zremrangebyscore key min max
> ZADD arcticle:ranking 51 arcticle:2 100 arcticle:3
(integer) 2
> ZREVRANGE arcticle:ranking 0 -1 WITHSCORES
1) "arcticle:1"
2) 200.0
3) "arcticle:3"
4) 100.0
5) "arcticle:2"
6) 51.0
> zremrangebyscore arcticle:ranking 50 100
2
> ZREVRANGE arcticle:ranking 0 -1 WITHSCORES
1) "arcticle:1"
2) 200.0
热门推荐
3亿人睡眠障碍咋办?3大科学助眠法让你一觉到天亮!
便血多久算是初期肠癌
日韩12项军力数据对比一览,日本装备强韩国兵力多,各有千秋
Win11Hyper-V虚拟机设置vGPU显卡直通 彻底释放GPU性能
中年人生,学会薄情,是一种智慧
废物资源综合利用减少环境污染
使用不当会引发火灾!“过冬神器”选购使用指南来了......
日文字符全览:轻松掌握五十音与汉字
93年!关于“飞将军”的秘密 有着跨越三代的守护
社交平台"贴贴"攻略:打造专属甜蜜瞬间的秘诀!
小康指数是什么?小康指数对经济发展有何意义?
交通事故监控录像鉴定:如何还原事故真相?
开源软件:推动软件行业繁荣的力量
学业挑战的智慧策略:提升孩子学习策略与效率的方法
古代武将与文官地位之谜
混沌起源新探索,揭开宇宙奥秘的神秘面纱
跨境电商产品选择技巧分享,六项选择剖析指南
校友会2024年中国大学排名:陕西高校表现亮眼
中国工程院黄和院士:合成生物学赋能食品制造,助力大健康产业升级发展
揭秘INFP纯爱战神的情感世界秘密
使用KernelSU的Root Android手机:完整指南
刘炫廷《NOBODY》首唱会成功举办 开启新一轮音乐之旅
身上莫名其妙的淤青,都是哪来的?
扣篮:运动表现训练的终极技能 - 深度剖析篮球基本功
比特币可以一直持有吗?5个维度帮你做出明智决策
猫尿不出来尿怎么解决?别慌!超全科普来啦!
五分钟掌握ADB:Android设备调试入门指南
DIY高性能电脑配置指南:从入门到高端硬件全解析
【AI绘画】Midjourney提示词详解:精细化技巧与高效实践指南
北京大视听 荣耀时刻 《特级英雄黄继光》以小正大,熟章焕然