驱动表与被驱动表mysql
先了解在join链接时哪一个表是驱动表,哪一个表是被驱动表:
1.当使用left join时,左表是驱动表,右表是被驱动表
2.当使用right join时,右表时驱动表,左表是驱动表
3.当使用join时,mysql会选择数据量比较小的表做为驱动表,大表做为被驱动表算法
join查询如何选择驱动表与被驱动表sql
在sql优化中,永远是以小表驱动大表。oop
例如: A是小表,B是大表
使用left join 时,则应该这样写select * from A a left join B b on a.code=b.code
A表时驱动表,B表是被驱动表测试
测试:A表140多条数据,B表20万左右的数据量
select * from A a left join B b on a.code=b.code
执行时间:7.5s优化
select * from B b left join A a on a.code=b.code
执行时间:19sspa
结论:小表驱动大表优于大表驱动小表.net
join查询在有索引条件下
驱动表有索引不会使用到索引
被驱动表创建索引会使用到索引code
在以小表驱动大表的状况下,再给大表创建索引会大大提升执行速度blog
测试:给A表,B表创建索引
分析:EXPLAIN select * from A a left join B b on a.code=b.code
只有B表code使用到索引
若是只给A表的code创建索引会是什么状况?
在这种状况下,A表索引失效
结论:给被驱动表创建索引
驱动表的含义
MySQL 表关联的算法是 Nest Loop Join,是经过驱动表的结果集做为循环基础数据,而后一条一条地经过该结果集中的数据做为过滤条件到下一个表中查询数据
,而后合并结果。若是还有第三个参与Join,则再经过前两个表的Join结果集做为循环基础数据,再一次经过循环查询条件到第三个表中查询数据,如此往复。
例如:
小表驱动大表:
for(140条){
for(20万条){
}
}
大表驱动小表:
for(20万条){
for(140条){
}
}
大表驱动小表,要经过20万次的链接
小表驱动小表,只须要经过140屡次的链接就能够了
因此也能够得出结论
若是A表,B表数据量差很少大的时候,那么选择谁做为驱动表也是无所谓了
忘了补充一句,也能够经过EXPLAIN分析来判断在sql中谁是驱动表,EXPLAIN语句分析出来的第一行的表便是驱动表
结论1.以小表驱动大表2.给被驱动表创建索引 ———————————————— 本文来源于:https://blog.csdn.net/qq_20891495/article/details/93744495