【Redis7】10大数据类型之Zset类型

2024-05-08 16:44

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

文章目录

  • 1.Zset类型
  • 2.常用命令
  • 3.示例
    • 3.1 ZADD,ZRANGE和ZREVRANGE
    • 3.2 ZSCORE,ZCARD和ZREM
    • 3.3 ZRANGEBYSCORE和ZCOUNT
    • 3.4 ZRANK和ZREVRANK
    • 3.5 Redis7新命令ZMPOP

1.Zset类型

Redis的Zset(Sorted Set,有序集合)是一种特殊的数据结构,它结合了集合(Set)和排序功能。在Zset中,每个成员(member)都关联一个唯一的分数(score),这个分数用于对集合中的成员进行排序。因此,Zset中的元素不仅像Set那样不允许重复,还能够根据score的值进行排序。

特性:

  • 有序性:Zset中的元素可以根据score的值进行升序或降序排列。
  • 唯一性:每个成员在Zset中都是唯一的,就像Set一样。
  • 分数(score):可以是任意浮点数,用于排序。相同的score值的成员会按照成员自身的字典顺序排序。
  • 时间复杂度:对于添加、删除和查找操作,平均时间复杂度通常为O(1),具体取决于跳跃列表(skiplist)的实现细节。
  • 跳跃列表(Skiplist):Redis使用跳跃列表作为Zset的底层实现,这是一种可以在对数时间内完成查找、插入和删除操作的数据结构。
  • 范围操作:支持快速地执行范围查询,如获取某个分数区间内的成员。

2.常用命令

  • ZADD key score member [score member ...]:向Zset中添加一个或多个成员及其分数。
  • ZRANGE key start stop [WITHSCORES]:返回Zset中指定范围内的成员,可选地包括它们的分数。
  • ZREVRANGE key start stop [WITHSCORES]:同ZRANGE,但返回的是按score降序排列的结果。
  • ZREM key member [member ...]:移除Zset中的一个或多个成员。
  • ZCARD key:返回Zset中成员的数量。
  • ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]:根据分数范围返回成员。
  • ZCOUNT key min max:返回Zset中score值在给定范围内的成员数量。
  • ZRANK key member:获取下标值
  • ZRANKANK key member:逆序获取下标值
  • ZMPOP numkeys key [key ...] MIN|MAX [COUNT count]:从键名列表中的第一个非空排序集中弹出一个或多个元素,它们是成员分数对

3.示例

3.1 ZADD,ZRANGE和ZREVRANGE

  • ZADD key score member [score member ...]:向Zset中添加一个或多个成员及其分数。
  • ZRANGE key start stop [WITHSCORES]:返回Zset中指定范围内的成员,可选地包括它们的分数。
  • ZREVRANGE key start stop [WITHSCORES]:同ZRANGE,但返回的是按score降序排列的结果。
127.0.0.1:6379> zadd zset1 10 v1 22.2 v2 30 v3 # 可以是浮点数
(integer) 3
127.0.0.1:6379> zrange zset1 0 -1
1) "v1"
2) "v2"
3) "v3"# 从大到小
127.0.0.1:6379> zrange zset1 0 -1 withscores # 从小到大
1) "v1"
2) "10"
3) "v2"
4) "22.199999999999999"
5) "v3"
6) "30"
127.0.0.1:6379> zrevrange zset1 0 -1 withscores # 从大到小
1) "v3"
2) "30"
3) "v2"
4) "22.199999999999999"
5) "v1"
6) "10"
127.0.0.1:6379> 

3.2 ZSCORE,ZCARD和ZREM

  • ZSCORE key member:用于获取有序集合中某个成员的分数(score)值。

  • ZREM key member [member ...]:移除Zset中的一个或多个成员。

  • ZCARD key:返回Zset中成员的数量。

127.0.0.1:6379> zcard zset1
(integer) 3
127.0.0.1:6379> zscore zset1 v1 
"10"
127.0.0.1:6379> zrem zset1 v1
(integer) 1
127.0.0.1:6379> zcard zset1
(integer) 2
127.0.0.1:6379> zrem zset1 v2 v3
(integer) 2
127.0.0.1:6379> zcard zset1
(integer) 0
127.0.0.1:6379> 

3.3 ZRANGEBYSCORE和ZCOUNT

ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]:根据分数范围返回成员。

ZCOUNT key min max:返回Zset中score值在给定范围内的成员数量。

127.0.0.1:6379> zadd zset1 10 v1 20 v2 30 v3 40 v4 50 v5
(integer) 5
127.0.0.1:6379> zrangebyscore zset1 20 40 # 不带分数
1) "v2"
2) "v3"
3) "v4"
127.0.0.1:6379> zrangebyscore zset1 20 40 withscores # 带分数
1) "v2"
2) "20"
3) "v3"
4) "30"
5) "v4"
6) "40"
127.0.0.1:6379> zrangebyscore zset1 (20 40 withscores # ( 的意思是不包含,可以理解为开区间,默认是闭区间
1) "v3"
2) "30"
3) "v4"
4) "40"
127.0.0.1:6379> zrangebyscore zset1 20 (40 withscores
1) "v2"
2) "20"
3) "v3"
4) "30"
127.0.0.1:6379> zrangebyscore zset1 20 40 withscores limit 0 2 # 从第几个结果返回几个数据
1) "v2"
2) "20"
3) "v3"
4) "30"
127.0.0.1:6379> zcount zset1 10 50 
(integer) 5
127.0.0.1:6379> zcount zset1 (10 50 
(integer) 4
127.0.0.1:6379> 

3.4 ZRANK和ZREVRANK

  • ZRANK key member:获取下标值
  • ZRANKANK key member:逆序获取下标值
127.0.0.1:6379> zadd zset1 10 v1 20 v2 30 v3 40 v4 50 v5
(integer) 5
127.0.0.1:6379> zrank zset1 v3
(integer) 2
127.0.0.1:6379> zrank zset1 v1
(integer) 0
127.0.0.1:6379> zrevrank zset1 v1
(integer) 4
127.0.0.1:6379> 

3.5 Redis7新命令ZMPOP

image-20240508155213579

ZMPOP numkeys key [key ...] MIN|MAX [COUNT count]:从键名列表中的第一个非空排序集中弹出一个或多个元素,它们是成员分数对

示例:

  • 从1个zset列表中弹出一个最小的
  • 从1个zset列表中弹出两个最大的
127.0.0.1:6379> ZMPOP 1 zset1 min count 1 # 从1个zset列表中弹出一个最小的
1) "zset1"
2) 1) 1) "v1"2) "10"
127.0.0.1:6379> ZMPOP 1 zset1 max count 2 # 从1个zset列表中弹出两个最大的
1) "zset1"
2) 1) 1) "v5"2) "50"2) 1) "v4"2) "40"
127.0.0.1:6379> 

这篇关于【Redis7】10大数据类型之Zset类型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/970873

相关文章

通过C#获取Excel单元格的数据类型的方法详解

《通过C#获取Excel单元格的数据类型的方法详解》在处理Excel文件时,了解单元格的数据类型有助于我们正确地解析和处理数据,本文将详细介绍如何使用FreeSpire.XLS来获取Excel单元格的... 目录引言环境配置6种常见数据类型C# 读取单元格数据类型引言在处理 Excel 文件时,了解单元格

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Pydantic中Optional 和Union类型的使用

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

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

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

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

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

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换

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

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

Python如何查看数据的类型

《Python如何查看数据的类型》:本文主要介绍Python如何查看数据的类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python查看数据的类型1. 使用 type()2. 使用 isinstance()3. 检查对象的 __class__ 属性4.

Python容器类型之列表/字典/元组/集合方式

《Python容器类型之列表/字典/元组/集合方式》:本文主要介绍Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 列表(List) - 有序可变序列1.1 基本特性1.2 核心操作1.3 应用场景2. 字典(D

python多种数据类型输出为Excel文件

《python多种数据类型输出为Excel文件》本文主要介绍了将Python中的列表、元组、字典和集合等数据类型输出到Excel文件中,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一.列表List二.字典dict三.集合set四.元组tuplepython中的列表、元组、字典