MySQL的LIMIT查询优化

摘要

本文主要是介绍MySQL LIMIT查询优化的具体内容,我们都知道MySQL数据库的优化是相当重要的,其中最常用也是最需要优化的就是LIMIT。MySQL的LIMIT给分页带来了极大的方便,但数据量一

本文主要是介绍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查询优化的介绍,望你能有所收获。


IT家园
IT家园

网友最新评论 (0)