今天发现有一天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
发现索引起效果了