最近、売れ筋商品リストを作成しましたが、その目的は、商品の売上高と売上高を組み合わせて総合的にスコアを計算し、売れ筋商品をランキングすることです。
初始化热销榜
对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 つのメンバーのみを追加または更新できました。