在项目中,我们有时可能会需要设计好友关注这个功能。如果用关系性数据库,例如MySQL可能会查询很慢,我们可以用Redis来实现这个功能。

如上图所示,在好友关注关系中,主要有以上三种状态,即:

  • 我的粉丝(fans)
  • 我的关注(follow)
  • 互粉(mutual)

假设两个用户。用户ID分别为1和2,。

关注

1、关注好友:

关注好友分为两个步骤。

第一步,将对方写入我的关注中。第二步,将我写入对方的粉丝中。即:

ZADD 1:follow time(时间戳) 2
ZADD 2:fans time(时间戳) 1

2、取消关注:

取消关注也分为两个步骤

第一步,将对方从我的关注中移除。第二步,将我从对方的粉丝中移除。即:

ZREM 1:follow 2
ZREM 2:fans 1

3、查看粉丝列表

ZRANGE 1:fans 0 -1

4、查看关注列表

ZRANGE 1:follow 0 -1

5、粉丝数量

ZCARD 1:fans

6、关注数量

ZCARD 1:follow


人物关系

1、我单向关注Ta。即我关注的Ta,但是Ta并没有关注我的

ZSCORE 1:follow 2 #ture
ZSCORE 1:fans 2 #false
如果第一条成立,第二条不成立,说明我单向关注了对方(1关注了2,而1的粉丝中没有2,说明2并没有关注1)。

2、Ta单向关注我。即Ta关注我了,我并没有关注Ta

ZSCORE 1:follow 2 #false
ZSCORE 1:fans 2 #true
如果第一条不成立,第二条成立,说明对方单向关注了我(1没有关注2,而1的粉丝中有2,说明2关注了1);

3、互相关注。即我关注了Ta,Ta也关注了我

ZSCORE 1:follow 2 #true
ZSCORE 1:fans 2 #true
如果上面两条都成立,即说明互相关注了(1关注了2,并且1的粉丝中有2,说明2也关注1了)。

我的互粉列表以及共同关注列表:

在查询出数据的时候可以将关系写入到临时表中,在这里就不再阐述了。




Logo

更多推荐