redis實現(xiàn)共同好友的思路詳解
背景
微信朋友圈的點贊、評論,只能看到自己好友的信息。這就涉及到了一個共同好友的概念,通過redis的set
集合可以很輕松的實現(xiàn)此功能。
共同好友實現(xiàn)思路
每個人的好友存放在set集合中。key的名字為friend_{userId}
。如下圖:
- 用戶1的好友為2,3,4
- 用戶2的好友為1,3,4
- 用戶3的好友為1,4,5
交集
用戶1和2是好友。他們的共同好友可以通過他們的交集獲取。
redis命令示例:
127.0.0.1:6379> sadd friend_1 2 3 4
(integer) 3
127.0.0.1:6379> sadd friend_2 1 4 5
(integer) 3
127.0.0.1:6379> SINTER friend_1 friend_2
1) “4”
sadd
將一個或多個成員元素加入到集合中,已經(jīng)存在于集合的成員元素將被忽略。命令詳解
SINTER
返回給定所有給定集合的交集。命令詳解
并集
獲得所有的好友信息。
127.0.0.1:6379> SUNION friend_1 friend_2
1) “1”
2) “2”
3) “3”
4) “4”
5) “5”
SUNION
返回給定集合的并集。命令詳解
差集
可以用戶好友推薦。差集出來的用戶推薦給用戶2。
127.0.0.1:6379> sadd friend_1 2 3 4
(integer) 3
127.0.0.1:6379> sadd friend_2 1 4 5
(integer) 3
127.0.0.1:6379> SDIFF friend_1 friend_2
1) “2”
2) “3”
SDIFF
返回第一個集合與其他集合之間的差異。命令詳解
更多set命令說明:
序號 | 命令及描述 |
---|---|
1 | SADD key member1 [member2] 向集合添加一個或多個成員 |
2 | SCARD key 獲取集合的成員數(shù) |
3 | SDIFF key1 [key2] 返回給定所有集合的差集 |
4 | SDIFFSTORE destination key1 [key2] 返回給定所有集合的差集并存儲在 destination 中 |
5 | SINTER key1 [key2] 返回給定所有集合的交集 |
6 | SINTERSTORE destination key1 [key2] 返回給定所有集合的交集并存儲在 destination 中 |
7 | SISMEMBER key member 判斷 member 元素是否是集合 key 的成員 |
8 | SMEMBERS key 返回集合中的所有成員 |
9 | SMOVE source destination member 將 member 元素從 source 集合移動到 destination 集合 |
10 | SPOP key 移除并返回集合中的一個隨機元素 |
11 | SRANDMEMBER key [count] 返回集合中一個或多個隨機數(shù) |
12 | SREM key member1 [member2] 移除集合中一個或多個成員 |
13 | SUNION key1 [key2] 返回所有給定集合的并集 |
14 | SUNIONSTORE destination key1 [key2] 所有給定集合的并集存儲在 destination 集合中 |
以上就是redis實現(xiàn)共同好友功能的詳細(xì)內(nèi)容,更多關(guān)于redis實現(xiàn)共同好友的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Redis源碼解析:集群手動故障轉(zhuǎn)移、從節(jié)點遷移詳解
這篇文章主要介紹了Redis源碼解析:集群手動故障轉(zhuǎn)移、從節(jié)點遷移的相關(guān)內(nèi)容,涉及通過集群定時器函數(shù)clusterCron實現(xiàn)從節(jié)點遷移等知識,具有一定參考價值,需要的朋友可以了解。2017-10-10使用Redis獲取數(shù)據(jù)轉(zhuǎn)json,解決動態(tài)泛型傳參的問題
這篇文章主要介紹了使用Redis獲取數(shù)據(jù)轉(zhuǎn)json,解決動態(tài)泛型傳參的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07Redis shake實現(xiàn)可視化監(jiān)控的示例代碼
Redis可視化監(jiān)控是通過監(jiān)控Redis服務(wù)器的各項指標(biāo)和狀態(tài),并將其以可視化的方式展示給用戶,本文給大家介紹了Redis shake實現(xiàn)可視化監(jiān)控,并通過代碼示例講解的非常詳細(xì),需要的朋友可以參考下2024-03-03