记一次子查询导致索引失效问题

论坛 期权论坛 脚本     
匿名技术用户   2021-1-7 21:06   11   0

今天发现有一天sql查询很慢,大概是这样的

SELECT * FROM dang_user WHERE id in(SELECT MAX(id) FROM dang_user WHERE if_use = 1 GROUP BY dang_username)

解析发现,这个语句没走索引,这里面的字段都是有索引的,后来强制 FORCE INDEX(id),还是不行,为什么呢,百度了一下,有两个知识点

第一个知识点:Mysql在处理所有的查询的时候都强行转换为联接来执行,将每个查询包括多表中关联匹配,关联子查询,union,甚至单表的的查询都处理为联接,接着Mysql执行联接,把每个联接在处理为一个嵌套循环;
第二个知识点:在Mysql在处理子查询的时候,会将子查询改写,Mysql将会扫描外查询中的所有数据,每条数据都将会传到子查询中进行关联,子查询不能首先被执行,如果外表很大的话,那么性能上将会出现问题。

后来改成这样

select d.*
from (select MAX(id) id from dang_user WHERE if_use = 1 GROUP BY dang_username) as o inner join dang_user d on o.id = d.id

发现索引起效果了

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:7942463
帖子:1588486
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP