Redis實(shí)戰(zhàn)筆記-文章投票系統(tǒng)

  1. 發(fā)布文章
    incr articleId 獲取新的遞增的文章id,
    hmset article:id 將文章詳情設(shè)置到hash中
    sadd voted:id posterId 將發(fā)布文章的用戶Id放入到已投票的集合中
    zadd time: now article:id 將文章的Id加入到按時(shí)間排序的有序集合中,分值為【當(dāng)前時(shí)間戳】
    zadd score: now+BASE_VOTE_SCORE article:id 將文章加入到按分值排序的有序集合中,分值為【當(dāng)前時(shí)間戳+投票數(shù)*每票的分?jǐn)?shù)】,這樣能夠做到最新的文章的基礎(chǔ)分?jǐn)?shù)比歷史文章高,排名能更靠前。

  2. 文章分組
    sadd group:groupName articleId 將文章加入到groupName組中
    srem group:groupName articleId 將文章從groupName組中刪除
    smove group:groupName1 groupName2 articleId 將文章從groupName1移動(dòng)到groupName2

  3. 文章投票
    sadd voted:articleId userId 將投票用戶id加入到已投票的集合中,如果返回0,說(shuō)明該用戶已經(jīng)為該文章投過(guò)票了,下邊的操作不繼續(xù)進(jìn)行
    zscore time: article:articleId 獲取被投票文章的發(fā)布時(shí)間,如果發(fā)布時(shí)間早于規(guī)定時(shí)間,不允許投票,下邊操作不繼續(xù)進(jìn)行
    hincr article:articleId votes 將文章詳情的votes加一
    zincrby score: articleId BASE_VOTE_SCORE 給排行榜的文章加基礎(chǔ)投票分

  4. 前端顯示
    zrevrange time: 0 10 按時(shí)間排序,獲取第一頁(yè)(前10條)的文章Id
    zrevrange score: 0 10 按投票數(shù)排序,獲取第一頁(yè)(前10條)的文章Id
    zinterstore time:groupName 2 group:groupName time: aggregate max 將分組groupName的文章按時(shí)間排序存入到time:groupName有序集合中
    zinterstore score:groupName 2 group:groupName score: aggregate max 將分組groupName的文章按評(píng)分排序,存入到score:groupName有序集合中
    zrevrange time:groupName 0 10 按時(shí)間順序,獲取第一頁(yè)(前10條)文章Id
    zrevrange score:groupName 0 10 按分?jǐn)?shù)順序,獲取第一頁(yè)(前10)的文章Id
    hgetall article:articleId 循環(huán)獲取上邊獲取的文章詳情

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容