redis-zset简单操作

最近搞了个商品热销榜,诉求是结合商品的销量和销售额,综合计算出一个分数,然后对商品做热销排序

初始化热销榜  
对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以前,命令只能添加或者更新一个成员。

猜你喜欢

转载自blog.csdn.net/qq_17033579/article/details/123478676