问题很简单:关于 mysql 的left join,若需关联的两张表数量都达到了几十万级别,会不会非常影响性能?
这时候还建议使用left join吗?还有其他优化的方案吗?
【Mysql 多表关联优化】
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
关注 建议把背景描述一下,看看是个什么需求,具体问题具体分析,不能一上来就好像必须要进行大表join。
比如如果最终结果需要经过where过滤,且只返回少量数据,那么可以先针对两个表分别过滤,然后再join。
而且如果机器配置好的话,几十万的数据真不算大。
你想一下,join之后,难道就把这几十万都输出到前端展现么?难道前端或者用户不会先指定查询条件?如果有指定查询条件的话,就不再需要对全部的数据去进行join了呀。当你第一个表把数据过滤掉了绝大部分,再去左关联其他表,也就只会去找剩下的这几行。
就算是不输入任何查询条件,分页其实也算是个条件,比如每页十行,第一个表查前十行记录作为子查询,再左连接其他表,得到第一页的数据。
mysql是可以设定内存占用大小的。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥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