百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

「Redis」五大常见的数据类型之 Zset

ztj100 2025-02-03 16:17 17 浏览 0 评论

前言

我们都知道 Redis 提供了丰富的数据类型,常见的有五种:String(字符串),Hash(哈希),List(列表),Set(集合)、Zset(有序集合)

今天我们就来详细地聊聊 Redis 这五大常见的数据类型之一 Zset;

结构类型

结构存储的值

结构读写能力

Zset

包含字符串的有序集合;

字符串成员与浮点数分数之间的有序映射;
元素的排列顺序由分数的大小决定;
添加,获取,删除单个元素;
根据分值范围或成员来获取元素;

应用场景:排序场景,比如排行榜、电话和姓名排序等。

概述简介

Zset 类型(有序集合类型)相比于 Set 类型多了一个排序属性 score(分值),对于有序集合 ZSet 来说,每个存储元素相当于有两个值组成的,一个是有序结合的元素值,一个是排序值。

有序集合保留了集合不能有重复成员的特性(分值可以重复),但不同的是,有序集合中的元素可以排序。

内部实现

Zset 类型的底层数据结构是由压缩列表或跳表实现的:

  • 如果有序集合的元素个数小于 128 个,并且每个元素的值小于 64 字节时,Redis 会使用压缩列表作为 Zset 类型的底层数据结构;
  • 如果有序集合的元素不满足上面的条件,Redis 会使用跳表作为 Zset 类型的底层数据结构;

在 Redis 7.0 中,压缩列表数据结构已经废弃了,交由 listpack 数据结构来实现了。

常用命令

Zset 常用操作:

# 往有序集合 key 中加入带分值元素
# ZADD key [NX|XX] [GT|LT] [CH] [INCR] score member [score member ...]
127.0.0.1:6379> ZADD usr:score 63 甲 70 乙 82 丙 89 丁 92 戊
(integer) 5

# 正序获取有序集合 key 从 start 下标到 stop 下标的元素
# ZRANGE key start stop [BYSCORE|BYLEX] [REV] [LIMIT offset count] [WITHSCORES]
127.0.0.1:6379> ZRANGE usr:score 0 -1
1) "\xe7\x94\xb2"
2) "\xe4\xb9\x99"
3) "\xe4\xb8\x99"
4) "\xe4\xb8\x81"
5) "\xe6\x88\x8a"

# 倒序获取有序集合 key 从 start 下标到 stop 下标的元素
# ZREVRANGE key start stop [WITHSCORES]
127.0.0.1:6379> ZREVRANGE usr:score 0 -1
1) "\xe6\x88\x8a"
2) "\xe4\xb8\x81"
3) "\xe4\xb8\x99"
4) "\xe4\xb9\x99"
5) "\xe7\x94\xb2"

# 往有序集合 key 中删除元素
# ZREM key member [member...]    
127.0.0.1:6379> ZREM usr:score  "\xe4\xb8\x99"
(integer) 1

# 返回有序集合 key 中元素 member 的分值
# ZSCORE key member
127.0.0.1:6379> ZSCORE usr:score "\xe4\xb9\x99"
"70"

# 返回有序集合 key 中元素个数
# ZCARD key 
127.0.0.1:6379> ZCARD usr:score
(integer) 4

# 为有序集合 key 中元素 member 的分值加上 increment
# ZINCRBY key increment member 
127.0.0.1:6379> ZINCRBY usr:score 11 "\xe4\xb9\x99" 
"81"

# 返回有序集合中指定分数区间内的成员,分数由低到高排序。
# ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]
127.0.0.1:6379> ZRANGEBYSCORE usr:score 79 90
1) "\xe4\xb9\x99"
2) "\xe4\xb8\x81"

# 返回指定成员区间内的成员,按字典正序排列, 分数必须相同。
# ZRANGEBYLEX key min max [LIMIT offset count]
127.0.0.1:6379> ZADD zset 0 a 0 aa 0 abc 0 apple 0 b 0 c 0 d 0 d1 0 dd 0 dobble 0 z 0 z1
(integer) 12
127.0.0.1:6379> ZRANGEBYLEX zset - +
 1) "a"
 2) "aa"
 3) "abc"
 4) "apple"
 5) "b"
 6) "c"
 7) "d"
 8) "d1"
 9) "dd"
10) "dobble"
11) "z"
12) "z1"
127.0.0.1:6379> ZRANGEBYLEX zset - + LIMIT 0 3
1) "a"
2) "aa"
3) "abc"

# 返回指定成员区间内的成员,按字典倒序排列, 分数必须相同
# ZREVRANGEBYLEX key max min [LIMIT offset count]
127.0.0.1:6379> ZREVRANGEBYLEX zset + -
 1) "z1"
 2) "z"
 3) "dobble"
 4) "dd"
 5) "d1"
 6) "d"
 7) "c"
 8) "b"
 9) "apple"
10) "abc"
11) "aa"
12) "a"

Zset 运算操作(相比于 Set 类型,ZSet 类型没有支持差集运算):

# 并集计算(相同元素分值相加),numberkeys一共多少个key,WEIGHTS每个key对应的分值乘积
ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]

# 交集计算(相同元素分值相加),numberkeys一共多少个key,WEIGHTS每个key对应的分值乘积
ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]

应用场景

Zset 类型(Sorted Set,有序集合) 可以根据元素的权重来排序,我们可以自己来决定每个元素的权重值。比如说,我们可以根据元素插入 Sorted Set 的时间确定权重值,先插入的元素权重小,后插入的元素权重大。

在面对需要展示最新列表、排行榜等场景时,如果数据更新频繁或者需要分页显示,可以优先考虑使用 Sorted Set。

排行榜

有序集合比较典型的使用场景就是排行榜。例如学生成绩的排名榜、游戏积分排行榜、视频播放排名、电商系统中商品的销量排名等。

我们以商品销售量为例,分别有五种商品,销售量为1243,321,98,432,2394;

# sale:1 商品的销售量为1243,以此类推
127.0.0.1:6379> ZADD mall 1243 sale:1
(integer) 1
127.0.0.1:6379> ZADD mall 321 sale:2
(integer) 1
127.0.0.1:6379> ZADD mall 98 sale:3
(integer) 1
127.0.0.1:6379> ZADD mall 432 sale:4
(integer) 1
127.0.0.1:6379> ZADD mall 2394 sale:5
(integer) 1

商品 sale:3 又卖出了一个,那么可以使用 ZINCRBY 命令(为有序集合 key 中元素 member 的分值加上 increment):

127.0.0.1:6379> ZINCRBY mall 1 sale:3
"99"

查看某个商品的销售量,可以使用 ZSCORE 命令(返回有序集合 key 中元素个数):

127.0.0.1:6379> ZSCORE mall sale:1
"1243"

获取销售量前三的商品,可以使用 ZREVRANGE 命令(倒序获取有序集合 key 从 start 下标到 stop 下标的元素):

# WITHSCORES 表示把 score 也显示出来
127.0.0.1:6379> ZREVRANGE mall 0 2 WITHSCORES
1) "sale:5"
2) "2394"
3) "sale:1"
4) "1243"
5) "sale:4"
6) "432"

获取销售量在 300 到 1000 的商品,可以使用 ZRANGEBYSCORE 命令(返回有序集合中指定分数区间内的成员,分数由低到高排序):

127.0.0.1:6379> ZRANGEBYSCORE mall 300 1000
1) "sale:2"
2) "sale:4"

电话、姓名排序

使用有序集合的 ZRANGEBYLEX 或 ZREVRANGEBYLEX 可以帮助我们实现电话号码或姓名的排序,我们以 ZRANGEBYLEX (返回指定成员区间内的成员,按 key 正序排列,分数必须相同)为例。

注意:不要在分数不一致的 SortSet 集合中去使用 ZRANGEBYLEX和 ZREVRANGEBYLEX 指令,因为获取的结果会不准确。

1、电话排序

我们可以将电话号码存储到 SortSet 中,然后根据需要来获取号段:

127.0.0.1:6379> ZADD phone 0 13100111100 0 13110114300 0 13132110901 
(integer) 3
127.0.0.1:6379> ZADD phone 0 13200111100 0 13210414300 0 13252110901 
(integer) 3
127.0.0.1:6379> ZADD phone 0 13300111100 0 13310414300 0 13352110901 
(integer) 3

获取所有号码:

127.0.0.1:6379> ZRANGEBYLEX phone - +
1) "13100111100"
2) "13110114300"
3) "13132110901"
4) "13200111100"
5) "13210414300"
6) "13252110901"
7) "13300111100"
8) "13310414300"
9) "13352110901"

获取 132 号段的号码:

127.0.0.1:6379> ZRANGEBYLEX phone [132 (133
1) "13200111100"
2) "13210414300"
3) "13252110901"

获取132、133号段的号码:

127.0.0.1:6379> ZRANGEBYLEX phone [132 (134
1) "13200111100"
2) "13210414300"
3) "13252110901"
4) "13300111100"
5) "13310414300"
6) "13352110901"

2、姓名排序

127.0.0.1:6379> zadd names 0 Toumas 0 Jake 0 Bluetuo 0 Gaodeng 0 Aimini 0 Aidehua 
(integer) 6

获取所有人的名字:

127.0.0.1:6379> ZRANGEBYLEX names - +
1) "Aidehua"
2) "Aimini"
3) "Bluetuo"
4) "Gaodeng"
5) "Jake"
6) "Toumas"

获取名字中大写字母 A 开头的所有人:

127.0.0.1:6379> ZRANGEBYLEX names [A (B
1) "Aidehua"
2) "Aimini"

获取名字中大写字母 C 到 Z 的所有人:

127.0.0.1:6379> ZRANGEBYLEX names [C [Z
1) "Gaodeng"
2) "Jake"
3) "Toumas"

后记

Redis 五大常见数据类型之一的 Zset 就先讲到这里了,后续还会有其他类型的讲解呢,敬请关注!

参考资料:

  • 《Redis 核心技术与实战》
  • 一文回顾 Redis 五大对象 (数据类型)
  • 谈谈Redis五种数据结构及真实应用场景
  • Redis的数据结构与应用场景
  • Redis 常见数据类型和应用场景

以上就是 【Redis】五大常见的数据类型之 Zset 的所有内容了,创作不易,多多支持

相关推荐

其实TensorFlow真的很水无非就这30篇熬夜练

好的!以下是TensorFlow需要掌握的核心内容,用列表形式呈现,简洁清晰(含表情符号,<300字):1.基础概念与环境TensorFlow架构(计算图、会话->EagerE...

交叉验证和超参数调整:如何优化你的机器学习模型

准确预测Fitbit的睡眠得分在本文的前两部分中,我获取了Fitbit的睡眠数据并对其进行预处理,将这些数据分为训练集、验证集和测试集,除此之外,我还训练了三种不同的机器学习模型并比较了它们的性能。在...

机器学习交叉验证全指南:原理、类型与实战技巧

机器学习模型常常需要大量数据,但它们如何与实时新数据协同工作也同样关键。交叉验证是一种通过将数据集分成若干部分、在部分数据上训练模型、在其余数据上测试模型的方法,用来检验模型的表现。这有助于发现过拟合...

深度学习中的类别激活热图可视化

作者:ValentinaAlto编译:ronghuaiyang导读使用Keras实现图像分类中的激活热图的可视化,帮助更有针对性...

超强,必会的机器学习评估指标

大侠幸会,在下全网同名[算法金]0基础转AI上岸,多个算法赛Top[日更万日,让更多人享受智能乐趣]构建机器学习模型的关键步骤是检查其性能,这是通过使用验证指标来完成的。选择正确的验证指...

机器学习入门教程-第六课:监督学习与非监督学习

1.回顾与引入上节课我们谈到了机器学习的一些实战技巧,比如如何处理数据、选择模型以及调整参数。今天,我们将更深入地探讨机器学习的两大类:监督学习和非监督学习。2.监督学习监督学习就像是有老师的教学...

Python教程(三十八):机器学习基础

...

Python 模型部署不用愁!容器化实战,5 分钟搞定环境配置

你是不是也遇到过这种糟心事:花了好几天训练出的Python模型,在自己电脑上跑得顺顺当当,一放到服务器就各种报错。要么是Python版本不对,要么是依赖库冲突,折腾半天还是用不了。别再喊“我...

超全面讲透一个算法模型,高斯核!!

...

神经网络与传统统计方法的简单对比

传统的统计方法如...

AI 基础知识从0.1到0.2——用“房价预测”入门机器学习全流程

...

自回归滞后模型进行多变量时间序列预测

下图显示了关于不同类型葡萄酒销量的月度多元时间序列。每种葡萄酒类型都是时间序列中的一个变量。假设要预测其中一个变量。比如,sparklingwine。如何建立一个模型来进行预测呢?一种常见的方...

苹果AI策略:慢哲学——科技行业的“长期主义”试金石

苹果AI策略的深度原创分析,结合技术伦理、商业逻辑与行业博弈,揭示其“慢哲学”背后的战略智慧:一、反常之举:AI狂潮中的“逆行者”当科技巨头深陷AI军备竞赛,苹果的克制显得格格不入:功能延期:App...

时间序列预测全攻略,6大模型代码实操

如果你对数据分析感兴趣,希望学习更多的方法论,希望听听经验分享,欢迎移步宝藏公众号...

AI 基础知识从 0.4 到 0.5—— 计算机视觉之光 CNN

...

取消回复欢迎 发表评论: