最近搞了个商品热销榜,诉求是结合商品的销量和销售额,综合计算出一个分数,然后对商品做热销排序
初始化热销榜
对set集合k1进行赋值:
zadd k1 1 a 2 b 3 c 4 d
(integer) 4
1 首先是热销榜商品列表(热销降序)
zrevrange k1 0 -1
1) "c"
2) "b"
3) "a"
4) "d"
2 如果商品无货,则不参与热销榜排名
移除集合k1里的元素d
zrem k1 d
(integer) 1
3 获取热销榜详情
zrange k1 0 -1
1) "a"
2) "b"
3) "c"
如果想获取商品综合分数
zrange k1 0 -1 withscores
1) "a"
2) "1"
3) "b"
4) "2"
5) "c"
6) "3"
4 能获取商品在榜单里的排名
逆向,倒序取排名,索引位置从0开始:
zrevrank k1 a
(integer) 3
选型数据结构为 用redis里的zset ,除了以上4点要求,它还能做到滤重且自动排序
是可以进行滤重的,通过结果可以看出:eg:
zadd k1 1 a 2 b 3 c
(integer) 0
`redis集合会按分数默认做好了排序,通过获取值即可看出 eg:
正向查询集合k1里的元素的位置:
zrank k1 c
(integer) 2
zrank k1 a
(integer) 0
扩展: 如果工作中有需要获取score的话,可以使用如下命令
查询集合k1的元素分数,即score:
zscore k1 a
"1"
zscore k1 c
"3"
>= 2.4 : 接受多个成员。 在Redis 2.4以前,命令只能添加或者更新一个成员。
|