Redis實現關註關係

来源:http://www.cnblogs.com/wjfz/archive/2016/04/13/5367472.html
-Advertisement-
Play Games

最近使用關係型資料庫實現了用戶之間的關註,於是思考換一種思路,使用Redis實現用戶之間的關註關係。 綜合考慮了一下Redis的幾種數據結構後,覺得可以用集合實現一下。 假設“我”的ID是1,“別人”的ID是2。 一、添加關註 添加關註分為兩步:1、將對方id添加到自己的關註列表中;2、將自己的id ...


最近使用關係型資料庫實現了用戶之間的關註,於是思考換一種思路,使用Redis實現用戶之間的關註關係。
綜合考慮了一下Redis的幾種數據結構後,覺得可以用集合實現一下。

假設“我”的ID是1,“別人”的ID是2。

一、添加關註

添加關註分為兩步:1、將對方id添加到自己的關註列表中;2、將自己的id添加到對方的粉絲列表中:

SADD 1:follow 2
SADD 2:fans 1

二、取消關註

取消關註同樣分為兩步:1、將對方id從自己的關註列表中移除;2、將自己的id從對方的粉絲列表中移除:

SREM 1:follow 2
SREM 2:fans 1

三、關註列表

查看我的關註列表:

SMEMBERS 1:follow

查看別人的把id換掉就可以

四、粉絲列表

查看我的粉絲列表:

SMEMBERS 2:fans

查看別人的把id換掉就可以

五、人物關係

5.1 我單向關註他

我單向關註他,要同時滿足兩個條件:1、我的關註列表中他(或他的粉絲列表中我);2、我的粉絲列表中沒有他(或他的關註列表中沒有我)。

SISMEMBER 1:follow 2  #true
SISMEMBER 1:fans 2    #false

5.2 他單向關註我

他單向關註我,要同時滿足兩個條件:1、我的關註列表中沒有他(或他的粉絲列表中沒有我);2、我的粉絲列表中他(或他的關註列表中我)。

SISMEMBER 1:follow 2  #false
SISMEMBER 1:fans 2    #true

5.3 我和某人是否互粉

我和某人是否互粉,要同時滿足兩個條件:1、我的關註列表中有他(或他的粉絲列表中有我);2、我的粉絲列表中有他(或他的關註列表中有我)。同時成立才為互粉。

SISMEMBER 1:follow 2  #true
SISMEMBER 1:fans 2    #true

互粉的關係是互相的,也可以反過來查。

六、我的互粉

查詢和我互粉的人,實際是對我的關註和我的粉絲求交集

SINTER 1:follow 1:fans

七、共同關註

查詢1和2的共同關註,實際是1的關註和2的關註求交集

SINTER 1:follow 2:follow

八、數量相關

8.1 我的關註數

SCARD 1:follow

8.2 我的粉絲數

SCARD 1:fans

九、問題

目前存在的問題是,我的關註列表 & 我的粉絲列表,無法做到按關註時間排序,終端下顯示是結果按ID正序排列的。
考慮的解決方案是添加關註時同時存一份有序集合,關註時的時間戳是score。

ZADD 1:follow 1457871625 2
ZADD 2:fans 1457871625 1

那麼我的關註列表是:

ZREVRANGE 1:follow 0 -1

同時,ZREVRANGE查詢時的索引可以作為分頁游標,基本解決目前的問題。

粉絲列表同理。

博客 http://blog.lovemydeer.com/2016/03/13/relation-with-redis.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 大叔第一人 之前寫了關於微信的坑《微信JSApi支付~坑和如何填坑》,今天將微信的jsapi支付封裝到了MVC環境里,當然也出現了一些新的坑,如支付參數應該是Json對象而不是Json字元串,這樣也會應付引起“get_brand_wcpay_request:fail_invalid appid”這個 ...
  • 註:科比今天要退役了,我是 60 億分之一,滿腹懷念~
  • atitit.userService 用戶系統設計 v6 q413 1. 新特性1 2. Admin login1 3. 用戶註冊登錄2 3.1. <!-- 會員註冊使用 --> 商家註冊2 3.2. <!-- 會員登錄使用 -->3 3.3. <!-- 會員退出登錄 -->3 3.4. <!-- ...
  • Atitit.獲取某個服務 網路鄰居列表 解決方案 原理,帶入某個ip掃描從0 255 很快,多線程幾秒就可以出來。 使用CountDownLatch來join線程.. 返回 [{ "ip":"192.168.2.114", "url":"http://@ip@:8080/cms/list_deta ...
  • 我是在前年的時候開始深入接觸C#的,所以,為什麼說是深入呢,大學裡面學過C#,但是,大學的學習你們是懂。剛進公司的三個多月,一直都是在熟悉C#的語法,後來我的頭就讓我做一個計算器的例子(基本上大家都做過這個例子),然後就直接做了,結果可想而知,運行時可以運行,但是只有一個class,頭看了之後,就讓 ...
  • 雙重鎖實現單例時遭到質疑,既是:雙重鎖也無法保證單例模式! 果然,答案又是對方對的,汗顏! 原因是:指令會重排序,普通的變數僅僅會保證該方法在執行時,所有依賴的賦值結果是正確的,但不會保證執行順序! 為什麼會重排序:指令重排序是指cpu採用了允許將多條指令不按照程式的順序分開發送各相應電路單元處理, ...
  • 最近在學習建模工具(StarUML)發現 其他功能一切正常 但是無法顯示代碼導出功能, 正常界面如下: 我的安裝確沒有導出功能缺少C++,C# ,Java等導出功能 解決辦法: 到StarUML安裝目錄下 找到需要導入語言文件夾, 例如c#對應文件夾staruml-csharp 打開文件夾 找到un ...
  • 裝飾模式是為已有功能動態的添加更多功能的一種方式。 當系統需要新功能的時候,是向舊的類中添加新的代碼,而這些新的代碼通常裝飾了原有類的核心職責或者主要行為, 這些新的邏輯增加了主類的複雜度,但是它們僅僅是滿足一些只在某這特定情況下才會執行的特殊行為的需要,且先後執行順序不確定。 這樣,每個要裝飾的功 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...