假設(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)于云服務(wù)器,域名注冊(cè),虛擬主機(jī)的問題,請(qǐng)?jiān)L問西部數(shù)碼官網(wǎng):m.ps-sw.cn