关于用户关注粉丝表设计方案的思考

本文涉及的产品
云数据库 Redis 版,标准版 2GB
推荐场景:
搭建游戏排行榜
云原生内存数据库 Tair,内存型 2GB
简介: 方案一方案二方案三


方案一



  • follow(关注关系表)
字段名 类型 索引 注解
id primaryKey()
user_id integer()->unsigned()->notNull() normal 用户
followed_user integer()->unsigned()->notNull() 关注的人的id
status smallInteger()->unsigned()->defaultValue(1) 关注状态:是否取消关注等
created_at integer()->unsigned()->notNull() normal
updated_at integer()->unsigned()->notNull() normal
用户每关注一个人,都会在表中添加一条数据

优点

1.设计简单,方便查询

2.可以区分关注的每一个人进行特殊处理(例如,不同人的关注事件,是否互粉,特别关注等),方便扩展

3.好写代码。

缺点

当用户量大时表数据量会非常庞大,因此必需要采用水平分表的方式将用户分散到多个表。

例如,有10万用户,ID为1~10000的用户放在表1(follow_1), ID为10001~20000的用户放在表2(follow_2), 以此类推。

然而分表后又会面临另一个问题,当被关注者依照多个表反查自己的粉丝时将会非常麻烦。因此需要再建一个粉丝表:

  • fans(粉丝表)
字段名 类型 索引 注解
id primaryKey()
user_id integer()->unsigned()->notNull() normal 用户
follower integer()->unsigned()->notNull() 粉丝
status smallInteger()->unsigned()->defaultValue(1) 关注状态:是否取消关注等
created_at integer()->unsigned()->notNull() normal
updated_at integer()->unsigned()->notNull() normal

此数据表依然需要做水平分表处理。


方案二



  • follow(关注关系表)
字段名 类型 索引 注解
id primaryKey()
user_id integer()->unsigned()->notNull() 唯一 用户
followed_user text 关注的人
follower text 粉丝
created_at integer()->unsigned()->notNull() normal
updated_at integer()->unsigned()->notNull() normal
以json格式记录每个用户关注的人和粉丝

优点

1.每个用户只有一条记录

2.方便查询

缺点

1.当粉丝数或关注的人数过大时,followed_user 和 follower 字段的数据长度会非常大,当用户关注的人或者粉丝数达到十万级别时,一条数据的数据量将会达到 兆 级别,将会极大地降低mysql的查询和php数据处理的效率。

2.每一次使用该表时都要将整条数据取出进行计算,对资源耗费太过严重。


方案三



使用redis的Hash数据类型

Redis hash是一个string类型的field和value的映射表。

Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿)。

每个用户分一张hash表,表名为用户id(可加前缀或后缀)

用户每关注一个人,便在hash表中添加一条数据

field: 关注用户的id

value:关注时间

  • user_1
field value
2 1483423443
3 1483423445
13 1483423440
... ...
  • user_2
field value
1 1483423443
5 1483423445
10 1483423440
... ...

......

优点

1.查询处理速度快。

缺点

1.消耗服务器内存和CPU。最好使用一台单独的服务器来运行 Redis

2.数据查询,处理不如关系型数据库灵活。

3.开发步骤复杂,学习成本高。


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
12月前
|
缓存 Java 关系型数据库
某人事系统架构搭建设计记录
某人事系统架构搭建设计记录
|
4月前
|
存储 关系型数据库 MySQL
表设计的10条军规
本文主要介绍了数据库建表的18个小技巧,包括:名字的命名规范、字段类型的选取、字段长度的控制、外键的使用、索引的创建、主键的选择、字段个数的限制、存储引擎的选择、时间字段的处理、金额字段的保存、冗余字段的使用以及注释的添加。作者强调了命名的重要性,如使用小写字母、避免全大写、使用下划线分隔等,并提倡使用NOT NULL和默认值,合理选择字段类型如datetime、decimal等,以及避免使用过多的字段和索引。此外,还提到了字符集和排序规则的选择,以及大字段和冗余字段的处理。
164 1
|
数据挖掘 网络架构
短链系统设计-服务设计
该系统其实很简单,只需要有一个 service即可:URL Service。由于 tiny url只有一个 UrlService: 本身其实就是个小的独立应用 也无需关心其他任何业务功能
134 0
短链系统设计-服务设计
|
SQL 消息中间件 存储
微博评论功能系统设计
微博评论功能是一种非常常见的社交媒体功能,设计好该功能需要考虑用户体验、安全性、性能和可扩展性等方面。在设计微博评论功能时,需要进行功能需求分析、数据库设计、后端API设计、前端设计、安全性设计、性能优化设计和可扩展性设计等方面的工作。通过以上设计方案的实现,可以实现一个功能完善、性能优良、安全可靠、可扩展的微博评论系统。
617 0
微博评论功能系统设计
|
设计模式 监控 Java
全网最全的权限系统设计方案
日常工作中权限的问题时时刻刻伴随着我们,程序员新入职一家公司需要找人开通各种权限,比如网络连接的权限、编码下载提交的权限、监控平台登录的权限、运营平台查数据的权限等等。
2987 1
|
SQL 缓存 NoSQL
社交系统中用户好友关系数据库设计
社交系统中用户好友关系数据库设计
1213 0
|
数据库
朋友圈或者qq动态相关的数据库设计
朋友圈或者qq动态相关的数据库设计
328 0
|
监控 安全 Java
全网最全的权限系统设计方案,不接受反驳!(1)
全网最全的权限系统设计方案,不接受反驳!
205 0
|
设计模式
全网最全的权限系统设计方案,不接受反驳!(2)
全网最全的权限系统设计方案,不接受反驳!
340 0
|
存储 SQL 分布式计算
用户/帖子/好友/订单中心如何进行数据库水平切分
用户/帖子/好友/订单中心如何进行数据库水平切分