溫馨提示×

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

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

實(shí)現(xiàn)排行榜功能

發(fā)布時(shí)間:2020-03-01 04:54:02 來(lái)源:網(wǎng)絡(luò) 閱讀:985 作者:梁十八 欄目:關(guān)系型數(shù)據(jù)庫(kù)

分別使用MongoDBRedis的有序集合來(lái)實(shí)現(xiàn)排行榜功能。對(duì)比傳統(tǒng)數(shù)據(jù)庫(kù)的排序功能,尋找有序集合實(shí)現(xiàn)排序功能的優(yōu)點(diǎn)。

實(shí)現(xiàn)排行榜功能

具體到一個(gè)實(shí)際例子,比如說(shuō)直播網(wǎng)站觀眾向主播送禮物的排行版,如果直接在數(shù)據(jù)庫(kù)里面進(jìn)行排序, 弊端有以下幾點(diǎn):
????? 排行榜會(huì)實(shí)時(shí)更新,數(shù)據(jù)每一次變化都要排序,會(huì)對(duì)數(shù)據(jù)庫(kù)的性能造成影響。. 頻繁更新數(shù)據(jù),導(dǎo)致數(shù)據(jù)庫(kù)性能下降。
????? 數(shù)據(jù)量太大時(shí)排序時(shí)間緩慢。
????? 對(duì)被排序字段添加索引會(huì)占用更多空間。

使用redis有序集合進(jìn)行排序:

????(1).直接把MongoDB中的數(shù)據(jù)導(dǎo)入到Redis中名為rank的有序集合中:

????????實(shí)現(xiàn)排行榜功能

????????實(shí)現(xiàn)排行榜功能

????(2).顯示某一個(gè)特定用戶的排名,具體代碼如下:

????????實(shí)現(xiàn)排行榜功能

????(3).顯示全部用戶的排名,具體代碼如下:

????????實(shí)現(xiàn)排行榜功能

????(4).運(yùn)行效果:

????????實(shí)現(xiàn)排行榜功能


????有序集合具有唯一性(假設(shè)rk為排行榜名稱,user1、user2等為玩家唯一標(biāo)識(shí))。score可以相同

????????實(shí)現(xiàn)排行榜功能

向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