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版本

相关推荐
啊吧怪不啊吧1 分钟前
极致性能的服务器Redis之Hash类型及相关指令介绍
大数据·数据库·redis·sql·mybatis·哈希算法
China_Yanhy6 分钟前
唯快不破:区块链项目的 Redis 缓存选型与实战指南
redis·缓存·区块链
王柏龙7 分钟前
ASP.NET Core 框架原生健康检查服务详解
后端·asp.net
不想写bug呀15 分钟前
Redis持久化:RDB与AOF
java·数据库·redis
浮尘笔记9 小时前
Go语言临时对象池:sync.Pool的原理与使用
开发语言·后端·golang
hanqunfeng9 小时前
(四十四)Redis8 新增的数据类型 -- Vector Set
数据库·redis·缓存
梦梦代码精10 小时前
BuildingAI vs Dify vs 扣子:三大开源智能体平台架构风格对比
开发语言·前端·数据库·后端·架构·开源·推荐算法
REDcker11 小时前
RESTful API设计规范详解
服务器·后端·接口·api·restful·博客·后端开发
没有bug.的程序员13 小时前
Java 序列化:Serializable vs. Protobuf 的性能与兼容性深度对比
java·开发语言·后端·反射·序列化·serializable·protobuf
此生只爱蛋14 小时前
【Redis】持久化
数据库·redis