本文主要是介绍MySQL LIMIT查询优化的具体内容,我们都知道MySQL数据库的优化是相当重要的,其中最常用也是最需要优化的就是LIMIT。MySQL的LIMIT给分页带来了极大的方便,但数据量一大的时候,LIMIT的性能就急剧下降。
同样是取10条数据,下面两条SQL语句:
SELECT * FROM yan_visit LIMIT 10000,10 SELECT * FROM yan_visit LIMIT 0,10
就不是一个数量级别的。
网上有很多LIMIT的优化准则,都是从MySQL手册翻译过来的,虽然正确但是不实用。今天发现一篇不错的关于LIMIT优化的文章。
文中不是直接使用LIMIT,而是首先获取到offset的id然后直接使用LIMITsize来获取数据。根据他的数据,明显要好于直接使用LIMIT。这里我具体使用数据分两种情况进行测试(测试环境win2003+p4双核 3GHZ+4G内存)。
1、offset较小时
SELECT * FROM yan_visit LIMIT 10,10
多次运行,时间保持在0.0004-0.0005之间。
SELECT * FROM yan_visit WHERE vid >=( SELECT vid FROM yan_visit ORDER BY vid LIMIT 10,1 ) LIMIT 10
多次运行,时间保持在0.0005-0.0006之间,主要是0.0006。
结论:偏移offset较小时,直接使用LIMIT较优。这个显然是子查询的原因。
2、offset较大时
SELECT * FROM yan_visit LIMIT 10000,10
多次运行,时间保持在0.0187左右。
SELECT * FROM yan_visit WHERE vid >=( SELECT vid FROM yan_visit ORDER BY vid LIMIT 10000,1 ) LIMIT 10
多次运行,时间保持在0.0061左右,只有前者的1/3。可以预计offset越大,后者越优。
以上的相关内容就是对MySQL LIMIT查询优化的介绍,望你能有所收获。