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

拡張機能:
作業中にスコアを取得する必要がある場合は、次のコマンドを使用できます。

查询集合k1的元素分数,即score:
zscore k1 a
"1"
zscore k1 c
"3"

>= 2.4:複数のメンバーを受け入れます。Redis 2.4 より前では、コマンドは 1 つのメンバーのみを追加または更新できました。

おすすめ

転載: blog.csdn.net/qq_17033579/article/details/123478676