redis实时计算TopK的想法
2022/1/23 19:04:52
本文主要是介绍redis实时计算TopK的想法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
想到这样的一个场景,你发了一个朋友圈,按照评论人评论的字数排序输出,字数越多表示越想想和你唠嗑。
场景1,一个人只能发一个评论的情况
使用redis的zset,假设需要排名前50个人,也就是Top50
思路
topk = 50 wordNum = len(user_id's comment) ZADD id wordNum user_id count = ZCARD id if (count > topk) { ZREMRANGEBYRANK 0, (topk - count) } ZRANGEBYSCORE id 0 -1 WITHSCORES
场景2,一个人能发多个评论的情况
使用redis的zset,但是需要记录所有的用户,唉,内存怎么搞?
假设需要排名前50个人,也就是Top50
思路
topk = 50 wordNum = len(user_id's comment) ZINCRBY id wordNum user_id ZRANGEBYSCORE id -topk -1 WITHSCORES
这篇关于redis实时计算TopK的想法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-08阿里云Redis项目实战入门教程
- 2024-11-08阿里云Redis资料:新手入门与初级使用指南
- 2024-11-08阿里云Redis教程:新手入门及实用指南
- 2024-11-07阿里云Redis学习入门:新手必读指南
- 2024-11-07阿里云Redis学习入门:从零开始的操作指南
- 2024-11-07阿里云Redis学习:初学者指南
- 2024-11-06阿里云Redis入门教程:轻松搭建与使用指南
- 2024-11-02Redis项目实战:新手入门教程
- 2024-10-22Redis入门教程:轻松掌握数据存储与操作
- 2024-10-22Redis缓存入门教程:快速掌握Redis缓存基础知识