Redis8中新特性:TopK获取最高排名的数据

前言

Redis8新增了新特性,可以利用TopK获取最高排名的数据

Topk使用

TOPK.RESERVE 初始化

yaml 复制代码
TOPK.RESERVE hello 20 2000 7 0.925
ini 复制代码
# 语法

#topk: 要保留的出现频率最高项目的数量。

#width: 每个数组中保留的计数器数量。(默认值 8)

#depth: 数组数量。(默认值 7)

#decay: 已占用桶中计数器减少的概率。它会对其计数器进行幂运算 (decay ^ bucket[i].counter)。因此,随着计数器值的升高,减少的几率会降低。(默认值 0.9)

TOPK.RESERVE key topk [width depth decay]

TOPK.ADD 添加一次

向数据结构添加一个项。可以一次添加多个项。如果一个项进入 Top-K 列表,则返回被逐出的项

语法为

css 复制代码
TOPK.ADD key items [items ...]

TOPK.INCRBY 带增量分数添加

按增量增加数据结构中项目的分数。可以一次增加多个项目的分数。如果某个项目进入 Top-K 列表,则返回被逐出的项目

TOPK.INFO 查看信息

返回所需项目数 (k)、宽度、深度和衰减值。

vbnet 复制代码
TOPK.INFO key

TOPK.LIST 查询Top K 列表

返回topk列表

css 复制代码
TOPK.LIST key [WITHCOUNT]

TOPK.QUERY 检查元素

语法

css 复制代码
TOPK.QUERY key item [item ...]

以下示例

yaml 复制代码
TOPK.RESERVE book1 2 2000 7 0.925
复制代码
TOPK.ADD book1 hello hello1 hello3 hello4
复制代码
TOPK.LIST book1
复制代码
TOPK.ADD book1 hello hello1

总结

可以利用TopK获取最高排名的数据,但是必须时Redis8版本

相关推荐
星辰徐哥6 小时前
Spring Boot 微服务架构设计与实现
spring boot·后端·微服务
星辰徐哥6 小时前
Spring Boot 数据导入导出与报表生成
spring boot·后端·ui
明夜之约6 小时前
Spring Boot 自动装配源码
java·spring boot·后端
Leaton Lee6 小时前
Spring Boot分层架构详解:从Controller到Service再到Mapper的完整流程
java·spring boot·后端·架构
Micro麦可乐6 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
Jinkxs6 小时前
Resilience4j- 与 Spring Boot 快速集成:自动配置与基础注解使用
java·spring boot·后端
毕设源码_郑学姐6 小时前
计算机毕业设计springboot网络相册设计与实现 基于Spring Boot框架的在线相册管理系统开发与应用 Spring Boot驱动的网络影集设计与实践
spring boot·后端·课程设计
辣机小司6 小时前
【踩坑记录:Spring Boot 配置文件读取值不一致?警惕 YAML 的“八进制陷阱”与 SnakeYAML 版本之谜】
java·spring boot·后端·yaml·踩坑记录
码农阿豪6 小时前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
追逐时光者6 小时前
一个基于 .NET 与 Avalonia 构建、面向 TrinityCore 的开源 WoW 数据库编辑器
后端·.net