关于群聊数据库的设计

日期 : 2021-04-06 13:46:20作者 : 熊人

萌新学编程,想试着做一个简单的群聊软件,希望可以实现一个建立临时群聊的功能,也就是说每个群的最长存在的时间可能不足 10 小时,想问下要怎么设计表结构才能最高效地实现群聊的创建删除和用户的加入功能呢。 暂时不考虑聊天功能之类的实现,只想知道如何实现房间表的设计。

简单的话,起步点只考虑建模还是比较直接的. 性能不够了之后再考虑优化。

先有个 users 表和 groups 表,里面有你任意想要的列。创建删除群聊就是创建删除 channel,然后删除设置 ORM 之类的,让删除 channel 的时候自动 delete_all,也就是清空相关的 messages 。

然后 user_groups 表作为关联表,有 user_id 和 channel_id,表示这个用户已经加入了这个 channel 。用户加入这个表就是插一条数据。

再来个 messages 表,有 message_body 内容 和 user_id 发言人,然后可能加上时间或者其他你想加的列。

最后 message_groups 表,表明这条 message 是发到哪个 group 的。

标签 :