行星意识 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 基于单片机数字电压表电路组成及框图
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line