文章详情页
mysql - inner join和left join的效率问题
浏览:141日期: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. $fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题2. python - 求一个在def中可以实现调用本def满足特定条件continue效果的方法(标题说不太清楚,请见题内描述)3. angular.js - angularjs的自定义过滤器如何给文字加颜色?4. javascript - 用表单提交两个时间段请求后台返回对应数据时出现的一些问题!5. java - mybatis怎么实现在数据库中有就修改,没有就添加6. MYSQL新建用户设置可以远程访问的问题7. mysql - SQL操作时间的函数?8. node.js - nodejs和前端JavaScript 字符串处理结果不一样是什么原因?9. docker api 开发的端口怎么获取?10. docker内创建jenkins访问另一个容器下的服务器问题
排行榜
![$fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题](http://www.haobala.com/attached/image/news/202205/093622cb60.png)