您好,登錄后才能下訂單哦!
分別使用MongoDB和Redis的有序集合來(lái)實(shí)現(xiàn)排行榜功能。對(duì)比傳統(tǒng)數(shù)據(jù)庫(kù)的排序功能,尋找有序集合實(shí)現(xiàn)排序功能的優(yōu)點(diǎ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的有序集合中:
????????
????????
????(2).顯示某一個(gè)特定用戶的排名,具體代碼如下:
????????
????(3).顯示全部用戶的排名,具體代碼如下:
????????
????(4).運(yùn)行效果:
????????
????有序集合具有唯一性(假設(shè)rk為排行榜名稱,user1、user2等為玩家唯一標(biāo)識(shí))。score可以相同
????????
免責(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)容。