geniuscrh 2009-07-14 15:02
浏览 2656
已采纳

聊天记录的数据库表设计

现在用户数量大致有10万人

所使用的数据库一定为mysql

想保存所有人聊天记录在在数据库中

即使一个人的聊天数据条数只有100条

那如果把所有记录保存在一张表中,那不就有1000万条记录

这样应该会导致查询效率极低吧?

有没有具体其的数据库设计方法或思想

比如多表?只是有这个想法,但是不懂其运作机制

大家说说想法,让小弟参考参考 谢谢了!

  • 写回答

5条回答 默认 最新

  • weixin_42297497 2009-07-14 15:53
    关注

    最佳解决方案:分表+备份
    分表:根据用户的id,把不同用户的聊天信息放到对应的表中,以缓解数据量的压力。
    备份:后台搞个过程,定期把老的数据备份的备份表里,同时把已备份的数据删除。
    我们公司类似这样的功能就是这么做的。

    还有一种方法,不如知道适不适合你的需求,那就是像qq一样,把该用户的聊天记录以文件的形式写在他本地.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥30 STM32 INMP441无法读取数据
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境