mongodb SNS design 问题
PHPz
PHPz 2017-04-24 09:13:30
0
1
607

在做一个小型社交网站时,需要涉及到用户状态评论等几张表,用户可以发表多个状态,每个状态下会有多个评论信息。
关于状态表和评论表的设计遇到了一些问题,即用户信息类似于用户名和用户头像等信息是否要embeded到两张表中,还是只在表中存放用户的ID信息。
现在有两种解决方案:

  • 两张表中只存放用户ID,用户具体信息存放在用户表中,但是这种方案在查询时会影响效率,特别是具体访问一条状态时,就要获取该状态的所有评论,而每条评论都要有用户的头像和昵称等等,若每次都分开查询的话,感觉效率会很低。
  • 在两张表中存放用户的信息,这种方法在查询时会非常方便,但是用户更新自身状态时会非常麻烦,要去遍历这两张表去逐个更新里面的信息。

不知具体应该选用哪种方案?或者是否有更好的方案?

PHPz
PHPz

学习是最好的投资!

全部回复(1)
洪涛

状态做子数组文档,单个状态下又有评论的子文档数组

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板