Redis 实现排名
前言
之前在消费金融平台的时候,公司有一个专门给线下销售人员使用的 APP,APP 记录销售推广公司贷款产品赚取的佣金以及一些门店开拓和打卡的功能,后端是由我和另外一个同事开发的,其中有一个模块是全国门店内的销售佣金实时排名,说到排名很多人的第一反应都是这是个 Top N 的问题,从数据库取出来用 MySQL 的 top 函数不就可以实现了,事实上当时无法从表里取到数据,数据还要配合权限,有全国和大区的排名,还需要计算大区经理下所有人员的有效佣金,还要求是实时的,从数据库读取再计算肯定不行,跳到排名页至少等待 5s 左右数据才能出来,那怎么办呢,可以放 Redis 里,那么接下来我们一起看看如何用 Redis 实现这个排名功能。
一.实现思路
使用的是 Redis 里 zset 数据类型,zset 的定义这里总结一下就是其每个元素都能够关联一个分数而且还能够针对集合元素进行排序,所以这点很合适用来排序,接下来我们一起看看如何用其实现排名功能。
二.具体实现
1.添加数据的方法包装
3.测试方法,乱序添加,如果想佣金从少到多在佣金前添加负号即可
4.执行结果
小结
zset 里除了计算排名的方法还有计算集合条件内个数的 zcount 方法,查看集合总个数 zcard 方法等等,用起来还是很方便的,但是还是那句话具体的只能到具体的业务里才知道实用不,而且还要注意 Redis 有数据淘汰策略,这个点也千万不要忽视了,还有就是针对已经废弃的业务数据还在缓存在 Redis 的里也要记得检查和清除掉。
版权声明: 本文为 InfoQ 作者【向往自由的太阳花】的原创文章。
原文链接:【http://xie.infoq.cn/article/0d5b267402e229f3eb2da8e1b】。文章转载请联系作者。
评论