四.4 Redis 五大数据类型/结构的详细说明/详细使用( zset 有序集合数据类型详解和使用)

四.4 Redis 五大数据类型/结构的详细说明/详细使用( zset 有序集合数据类型详解和使用)

文章目录

  • [四.4 Redis 五大数据类型/结构的详细说明/详细使用( zset 有序集合数据类型详解和使用)](#四.4 Redis 五大数据类型/结构的详细说明/详细使用( zset 有序集合数据类型详解和使用))
  • [1. 有序集合 Zset(sorted set)](#1. 有序集合 Zset(sorted set))
  • [2. zset 有序集合常用指令(详细讲解说明)](#2. zset 有序集合常用指令(详细讲解说明))
    • [2.1 `zadd <key><score1><value1><score2><value2>...` 将一个或多个 member 元素及其 score 值加入 到有序集 key 当中。](#2.1 zadd <key><score1><value1><score2><value2>… 将一个或多个 member 元素及其 score 值加入 到有序集 key 当中。)
    • [2.2 `zrange <key><start><stop> [WITHSCORES]` 返回有序集 key 中,下标在`<start><stop>`之间的元素, 带 WITHSCORES,可以让分数一起和值返回到结果集,返回的结果是"升序"](#2.2 zrange <key><start><stop> [WITHSCORES] 返回有序集 key 中,下标在<start><stop>之间的元素, 带 WITHSCORES,可以让分数一起和值返回到结果集,返回的结果是“升序”)
    • [2.3 `zreverange <key><start><stop> [WITHSCORES]` 返回有序集 key 中,下标在`<start><stop>`之间的元素, 带 WITHSCORES,可以让分数一起和值返回到结果集,返回的是"降序"](#2.3 zreverange <key><start><stop> [WITHSCORES] 返回有序集 key 中,下标在<start><stop>之间的元素, 带 WITHSCORES,可以让分数一起和值返回到结果集,返回的是“降序”)
    • [2.4 `zscore <key><member> ` 返回有序集 key 中,成员 member 的 score 值](#2.4 zscore <key><member> 返回有序集 key 中,成员 member 的 score 值)
    • [2.5 `zrangebyscore key min max [withscores] [limit offset count]` 返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从小到大)次序排列。](#2.5 zrangebyscore key min max [withscores] [limit offset count] 返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从小到大)次序排列。)
    • [2.6 `zrevrangebyscore key max min [withscores] [limit offset count] 同上`,改为从大到小排列](#2.6 zrevrangebyscore key max min [withscores] [limit offset count] 同上,改为从大到小排列)
    • [2.7 `zincrby <key><increment><value> ` 为元素的 score 加上增量](#2.7 zincrby <key><increment><value> 为元素的 score 加上增量)
    • [2.8 `zrem <key><value>` 删除该集合下,指定值的元素](#2.8 zrem <key><value> 删除该集合下,指定值的元素)
    • [2.9 `zcount <key><min><max>` 统计该集合,分数区间内的元素个数](#2.9 zcount <key><min><max> 统计该集合,分数区间内的元素个数)
    • [2.10 `zrank <key><value>` 返回该值在集合中的排名,从 0 开始](#2.10 zrank <key><value> 返回该值在集合中的排名,从 0 开始)
  • [3. 最后:](#3. 最后:)

1. 有序集合 Zset(sorted set)

  1. Redis 有序集合 zset 与 普通集合 set 非常相似,时一个没有重复元素的字符串集合
  2. 不同之处是有序集合的每个成员都关联了一个评分(score) ,这个评分(score) 被用来按照,从最低分到最高分的方式排序集合中的成员。集合的成员是唯一的,但是评分是可以重复的。
  3. 因为元素是有序的,所以有可以很快的根据评分(score) 或者次序 (position)来获取一个范围的元素内容。
  4. 访问有序集合的中间元素也是非常快的,你能够使用有序集合作为一个没有重复成员的列表。

sorted set 指令示意图- 案例蜀国五虎将:

2. zset 有序集合常用指令(详细讲解说明)

关于 zset 有序集合的命令,在 Redis 当中有如下这些:

这里我们介绍一些 zset 有序集合比较常用的一些命令,然后,举一反三,根据文档也可以对其它的命令上手学习使用了

2.1 zadd <key><score1><value1><score2><value2>... 将一个或多个 member 元素及其 score 值加入 到有序集 key 当中。

sh 复制代码
127.0.0.1:6379> zadd hero 1 "gy" 2 "zf" 3 "zy" 4 "mc" 5 "hz"

2.2 zrange <key><start><stop> [WITHSCORES] 返回有序集 key 中,下标在<start><stop>之间的元素, 带 WITHSCORES,可以让分数一起和值返回到结果集,返回的结果是"升序"

sh 复制代码
127.0.0.1:6379> zrange hero 0 -1

注意: zrange 后面可以追加上,带 WITHSCORES,可以让分数一起和值返回到结果集。默认是根据 score 评分进行一个升序排序的。

2.3 zreverange <key><start><stop> [WITHSCORES] 返回有序集 key 中,下标在<start><stop>之间的元素, 带 WITHSCORES,可以让分数一起和值返回到结果集,返回的是"降序"

使用和 zrange 是一样的。

sh 复制代码
127.0.0.1:6379> zrevrange hero 0 -1
sh 复制代码
127.0.0.1:6379> zrevrange hero 0 -1 withscores

2.4 zscore <key><member> 返回有序集 key 中,成员 member 的 score 值

sh 复制代码
127.0.0.1:6379> zscore hero gy

2.5 zrangebyscore key min max [withscores] [limit offset count] 返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从小到大)次序排列。

sh 复制代码
127.0.0.1:6379> zrangebyscore hero 1 3

2.6 zrevrangebyscore key max min [withscores] [limit offset count] 同上,改为从大到小排列

sh 复制代码
127.0.0.1:6379> zrevrangebyscore hero 5 1

2.7 zincrby <key><increment><value> 为元素的 score 加上增量

sh 复制代码
127.0.0.1:6379> zincrby hero 4 zf

当然,也可以是 - score评分值了

sh 复制代码
127.0.0.1:6379> zincrby hero -4 zf

2.8 zrem <key><value> 删除该集合下,指定值的元素

sh 复制代码
127.0.0.1:6379> zrem hero "zy"

2.9 zcount <key><min><max> 统计该集合,分数区间内的元素个数

sh 复制代码
127.0.0.1:6379> zcount hero 2 10

2.10 zrank <key><value> 返回该值在集合中的排名,从 0 开始

sh 复制代码
127.0.0.1:6379> zrank hero gy

3. 最后:

"在这个最后的篇章中,我要表达我对每一位读者的感激之情。你们的关注和回复是我创作的动力源泉,我从你们身上吸取了无尽的灵感与勇气。我会将你们的鼓励留在心底,继续在其他的领域奋斗。感谢你们,我们总会在某个时刻再次相遇。"

相关推荐
贫民窟的勇敢爷们4 分钟前
SpringBoot多环境配置全解+配置优先级管控
java·spring boot·后端
霸道流氓气质8 分钟前
Spring AI ChatMemory 对话记忆配置JDBC方式到Mysql数据库实战示例与原理讲解
数据库·人工智能·spring
tellmewhoisi10 分钟前
单独抽取用户服务(请求不通):feign添加拦截器(添加token)
java·开发语言
ZC跨境爬虫11 分钟前
跟着MDN学HTML_day_45:(EventTarget接口)
前端·javascript·ui·html·媒体
与数据交流的路上14 分钟前
Redis-jedis连接池配置错误导致Redis CPU飙高
数据库·redis·缓存
杂家14 分钟前
Windows部署Redis
数据库·windows·redis
YL2004042622 分钟前
035LRU缓存
java·leetcode·缓存
IpdataCloud24 分钟前
电商防刷单:如何用IP风险识别工具拦截虚假交易?实操指南
数据库
漂移的电子25 分钟前
【el-tree】外层多选,某个属性内层单选
前端·javascript·vue.js
m0_7407963628 分钟前
golang如何实现工作流引擎_golang工作流引擎实现要点
jvm·数据库·python