为什么MySQL的IN操作在大于3个操作数时不用索引?
1,从MySQL5.6版本开始,对where in做了优化,是走索引的,用EXPLAIN 分析你的SQL,你会发现type 都是 range,表示使用索引范围查询, 通过索引字段范围获取表中部分数据记录。
2,在MySQL5.5版本中,where in虽然不会走索引,但该版本在下面这种情况下对where in是做了优化的,比如select * from a where I'd in (select a_id from b) 会优化为 select * from a where exists(select * from b where b.a_id=a.id);
exists 相关子查询的执行原理是:循环取出 a 表的每一条记录与 b 表进行比较,比较的条件是 a.id=b.id。看 a 表的每条记录的 id 是否在 b 表存在,如果存在就行返回 a 表的这条记录。
Copyright © 广州京杭网络科技有限公司 2005-2024 版权所有 粤ICP备16019765号
广州京杭网络科技有限公司 版权所有