文章详情页
mysql - inner join和left join的效率问题
浏览:187日期:2022-06-11 08:37:23
问题描述
inner join和left join各自在什么情景下执行效率会相对高些呢?
问题解答
回答1:left join在任何场景下都不会比inner join的执行效率高 因为left join除了需要所有inner join的结果集以外还需要左表的所有没有关联上的数据
left join除了要求关联字段有索引以外,最好将小表作为左表,因为检索的循环次数更少,前提是你的业务逻辑没问题,因为不同的写法逻辑是不一样的
inner join会自动选择合适的表作为基础表,也仍然要求有关联字段索引,并且最好是int型检索效率更高
回答2:说真心的,你问问题的方向也不太对。。。只是限制条件和索引还是查询合理,速度都很快inner join 不以谁为基础,展示符合条件的数据left join 以左为基础,连右表
就效率来说 肯定是小表连大表快从一个MySQL left join优化的例子加深对查询计划的理解
相关文章:
1. docker不显示端口映射呢?2. docker-compose中volumes的问题3. boot2docker无法启动4. dockerfile - 我用docker build的时候出现下边问题 麻烦帮我看一下5. docker api 开发的端口怎么获取?6. docker images显示的镜像过多,狗眼被亮瞎了,怎么办?7. mysql - phpmyadmin怎么分段导出数据啊?8. macos - mac下docker如何设置代理9. debian - docker依赖的aufs-tools源码哪里可以找到啊?10. docker start -a dockername 老是卡住,什么情况?
排行榜

网公网安备