文章开篇前,先问大家一个问题:delete in子查询,是否会走索引呢?很多伙伴第一感觉就是:会走索引。最近我们有个生产问题,就跟它有关。本文将跟大家一起探讨这个问题,并附上优化方案。
MySQL版本是5.7
,假设当前有两张表account
和old_account
,表结构如下:
执行的SQL如下:
从explain
结果可以发现:先全表扫描 account
,然后逐行执行子查询判断条件是否满足;显然,这个执行计划和我们预期不符合,因为并没有走索引。
但是如果把delete
换成select
,就会走索引。如下:
为什么select in子查询会走索引,delete in子查询却不会走索引呢?
select in
子查询语句跟delete in
子查询语句的不同点到底在哪里呢?
我们执行以下SQL看看
那如何优化这个问题呢?通过上面的分析,显然可以把delete in子查询
改为join的方式。我们改为join的方式后,再explain看下:
what?为啥加个别名,delete in子查询又行了,又走索引了?
我们回过头来看看explain的执行计划,可以发现Extra那一栏,有个LooseScan。
本博文分析了delete in子查询不走索引的原因,并附上解决方案。delete in
在日常开发,是非常常见的,平时大家工作中,需要注意一下。同时呢,建议大家工作的时候,写SQL的时候,尽量养成一个好习惯,先用explain分析一下SQL。
本文整体思路参考同事的博文,已经经过他本人同意。也建议大家遇到问题时,多点思考,多点写写总结,避免重蹈覆辙。
若有收获,请记得三连发,分享,点赞,在看
本文发布于:2024-02-05 07:06:41,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170726993164266.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |