IM系统 表设计问题

很好奇为什么要分发送消息表接收消息表,为什么不放在一个表,再用一个字段区分呢?

阅读 3k
1 个回答

这种问题意义不大。


其实稍微深入思考一下就能明白了。怎么思考呢,罗列一下他们各自的优缺点。

  • 如果数据量不大,一个表存方便快捷。
  • 数据量大一些呢,某些场景下,拆开查询效率更高。
  • 如果数据量再大呢,可能就要考虑按用户ID等维度去拆表了。

有时,原系统的一些设计 可能本身考虑不足,只解决了部分问题。有时,可能考虑的比较多,要深入思考后才能理解。

再说到这个问题,既然只是拆了发送接收 数据量一般。那种设计都可以~ (除非有特殊场景)

推荐问题