首页 >

为什么MySQL的IN操作在大于3个操作数时不用索引 – 数据库 – 前端,mysql 同步跳错误

linux设置mysql权限设置,mysql 表数据插入,python 3安装mysql库,delphi每次mysql密码BDE,mysql 2003 local,mysql 同步跳错误为什么MySQL的IN操作在大于3个操作数时不用索引 - 数据库 - 前端,mysql 同步跳错误

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 同步跳错误为什么MySQL的IN操作在大于3个操作数时不用索引 - 数据库 - 前端,mysql 同步跳错误


为什么MySQL的IN操作在大于3个操作数时不用索引 - 数据库 - 前端,mysql 同步跳错误
  • f1f2键盘快捷键不能用什么原因 - 数据库 - 前端|
  • f1f2键盘快捷键不能用什么原因 - 数据库 - 前端| | f1f2键盘快捷键不能用什么原因 - 数据库 - 前端| ...

    为什么MySQL的IN操作在大于3个操作数时不用索引 - 数据库 - 前端,mysql 同步跳错误
  • mysql 数据库存放,mysql一张表多少数据合适 - 数据库 - 前端,查看mysql的用户名和密码是什么
  • mysql 数据库存放,mysql一张表多少数据合适 - 数据库 - 前端,查看mysql的用户名和密码是什么 | mysql 数据库存放,mysql一张表多少数据合适 - 数据库 - 前端,查看mysql的用户名和密码是什么 ...

    为什么MySQL的IN操作在大于3个操作数时不用索引 - 数据库 - 前端,mysql 同步跳错误
  • SQLite能胜任简单的企业级业务数据库吗 - 数据库 - 前端|
  • SQLite能胜任简单的企业级业务数据库吗 - 数据库 - 前端| | SQLite能胜任简单的企业级业务数据库吗 - 数据库 - 前端| ...