mysql小表驱动大表
摘要:
小表驱动大表是优化器从成本考虑后做出的选择
判断谁做小表时,是比较算上过滤条件后的字段+条数的总大小
小表驱动大表在执行计划中体现,第一行是小表第二行是大表。不是在show warnings体现
left join时右表过滤条件在where,优化器会转为inner join小表驱动大表。
left join时右表过滤条件在on,优化器不会优化成小表驱动大表,因为无法转为inner join,所以要自己把小表放左边,大表放右边
inner join时优化器会自动小表驱动大表
course–100条数据
student_info–100w条数据
优化器会选择小表驱动大表(这里表指的是算上过滤条件的表)
`EXPLAINSELECT a.*,b.* FROM `course` a JOIN `student_info` b ON a.`course_id`=b.`course_id`
EXPLAIN SELECT a.* FROM `student_info` a JOIN `course` b ON a.`course_id`=b.`course_id`
加上过滤student_info的条件
EXPLAINSELECT a.*,b.* FROM `course` a JOIN `student_info` b ON a.`course_id`=b.`course_id` WHERE b.`student_id`=1
执行计划改变,由小表student_info驱动大表course,得出优化器先走where后join的结论。
查看优化器优化后的sql
show warnings
from atguigudb1
.course
a
join atguigudb1
.student_info
b
where ((atguigudb1
.a
.course_id
= atguigudb1
.b
.course_id
) and (atguigudb1
.b
.student_id
= 1))
left join时右表过滤条件在where,优化器会转为inner join小表驱动大表。
EXPLAINSELECT a.*,b.* FROM `course` a LEFT JOIN `student_info` b ON a.`course_id`=b.`course_id` WHERE b.`student_id`=1
查看优化器优化后的sql
show warnings
FROM atguigudb1
.course
a
JOIN atguigudb1
.student_info
b
WHERE ((atguigudb1
.a
.course_id
= atguigudb1
.b
.course_id
) AND (atguigudb1
.b
.student_id
= 1))
来源地址:https://blog.csdn.net/qq_39331255/article/details/131192562
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341