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 表的这条记录。
linux设置mysql权限设置,mysql 表数据插入,python 3安装mysql库,delphi每次mysql密码BDE,mysql 2003 local,mysql 同步跳错误