redis实现共同好友 redis实现共同好友的思路详解
叁滴水 人气:1想了解redis实现共同好友的思路详解的相关内容吗,叁滴水在本文为您仔细讲解redis实现共同好友的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:redis实现共同好友,redis共同好友,下面大家一起来学习吧。
背景
微信朋友圈的点赞、评论,只能看到自己好友的信息。这就涉及到了一个共同好友的概念,通过redis的set
集合可以很轻松的实现此功能。
共同好友实现思路
每个人的好友存放在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
将一个或多个成员元素加入到集合中,已经存在于集合的成员元素将被忽略。命令详解
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 获取集合的成员数 |
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] 返回集合中一个或多个随机数 |
12 | SREM key member1 [member2] 移除集合中一个或多个成员 |
13 | SUNION key1 [key2] 返回所有给定集合的并集 |
14 | SUNIONSTORE destination key1 [key2] 所有给定集合的并集存储在 destination 集合中 |
加载全部内容