行星意识 2022-04-23 16:08 采纳率: 75%
浏览 43
已结题

【Mysql 多表关联优化】

问题很简单:关于 mysql 的left join,若需关联的两张表数量都达到了几十万级别,会不会非常影响性能?
这时候还建议使用left join吗?还有其他优化的方案吗?

  • 写回答

2条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-04-23 22:42
    关注

    建议把背景描述一下,看看是个什么需求,具体问题具体分析,不能一上来就好像必须要进行大表join。
    比如如果最终结果需要经过where过滤,且只返回少量数据,那么可以先针对两个表分别过滤,然后再join。
    而且如果机器配置好的话,几十万的数据真不算大。


    你想一下,join之后,难道就把这几十万都输出到前端展现么?难道前端或者用户不会先指定查询条件?如果有指定查询条件的话,就不再需要对全部的数据去进行join了呀。当你第一个表把数据过滤掉了绝大部分,再去左关联其他表,也就只会去找剩下的这几行。
    就算是不输入任何查询条件,分页其实也算是个条件,比如每页十行,第一个表查前十行记录作为子查询,再左连接其他表,得到第一页的数据。
    mysql是可以设定内存占用大小的。

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

报告相同问题?

问题事件

  • 系统已结题 5月1日
  • 已采纳回答 4月23日
  • 创建了问题 4月23日

悬赏问题

  • ¥15 用hfss做微带贴片阵列天线的时候分析设置有问题
  • ¥50 我撰写的python爬虫爬不了 要爬的网址有反爬机制
  • ¥15 Centos / PETSc / PETGEM
  • ¥15 centos7.9 IPv6端口telnet和端口监控问题
  • ¥120 计算机网络的新校区组网设计
  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 海浪数据 南海地区海况数据,波浪数据
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等