溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

使用Redis實(shí)現(xiàn)排行榜功能的方法

發(fā)布時(shí)間:2020-08-15 10:25:00 來(lái)源:億速云 閱讀:239 作者:小新 欄目:關(guān)系型數(shù)據(jù)庫(kù)

這篇文章給大家分享的是有關(guān)使用Redis實(shí)現(xiàn)排行榜功能的方法的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧。

下面由Redis教程欄目給大家介紹使用Redis實(shí)現(xiàn)排行榜功能的方法,希望對(duì)需要的朋友有所幫助!

使用Redis實(shí)現(xiàn)排行榜功能的方法

排行榜功能是一個(gè)很普遍的需求。使用 Redis 中有序集合的特性來(lái)實(shí)現(xiàn)排行榜是又好又快的選擇。

一般排行榜都是有實(shí)效性的,比如“用戶積分榜”。如果沒(méi)有實(shí)效性一直按照總榜來(lái)排,可能榜首總是幾個(gè)老用戶,對(duì)于新用戶來(lái)說(shuō),那真是太令人沮喪了。

首先,來(lái)個(gè)“今日積分榜”吧,排序規(guī)則是今日用戶新增積分從多到少。

那么用戶增加積分時(shí),都操作一下記錄當(dāng)天積分增加的有序集合。
假設(shè)今天是 2015 年 04 月 01 日,UID 為 1 的用戶因?yàn)槟硞€(gè)操作,增加了 5 個(gè)積分。
Redis 命令如下:

ZINCRBY rank:20150401 5 1

假設(shè)還有其他幾個(gè)用戶也增加了積分:

ZINCRBY rank:20150401 1 2
ZINCRBY rank:20150401 10 3

看看現(xiàn)在有序集合 rank:20150401 中的數(shù)據(jù)(withscores 參數(shù)可以附帶獲取元素的 score):

ZRANGE rank:20150401 0 -1 withscores
1) "2"
2) "1"
3) "1"
4) "5"
5) "3"
6) "10"

按照分?jǐn)?shù)從高到低,獲取 top10:

ZREVRANGE rank:20150401 0 9 withscores
1) "3"
2) "10"
3) "1"
4) "5"
5) "2"
6) "1"

因?yàn)橹挥腥齻€(gè)元素,所以就查詢出了這些數(shù)據(jù)。

如果每天記錄當(dāng)天的積分排行榜,那么其他花樣百出的榜單也就簡(jiǎn)單了。
比如“昨日積分榜”:

ZREVRANGE rank:20150331 0 9 withscores

利用并集實(shí)現(xiàn)多天的積分總和,實(shí)現(xiàn)“上周積分榜”:

ZUNIONSTORE rank:last_week 7 rank:20150323 rank:20150324 rank:20150325 rank:20150326 rank:20150327 rank:20150328 rank:20150329 WEIGHTS 1 1 1 1 1 1 1

這樣就將 7 天的積分記錄合并到有序集合 rank:last_week 中了。權(quán)重因子 WEIGHTS 如果不給,默認(rèn)就是 1。為了不隱藏細(xì)節(jié),特意寫出。
那么查詢上周積分榜 Top10 的信息就是:

ZREVRANGE rank:last_week  0 9 withscores

“月度榜”、“季度榜”、“年度榜”等等就以此類推。

感謝各位的閱讀!關(guān)于使用Redis實(shí)現(xiàn)排行榜功能的方法就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI