`

mysql limit字句

阅读更多
在我们使用查询语句的时候,经常要返回前几条或者中间某几行数据,这个时候怎么办呢?不用担心,mysql已经为我们提供了这样一个功能。
SELECT * FROM table  LIMIT [offset,] rows | rows OFFSET offset 



LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。初始记录行的偏移量是 0(而不是 1): 为了与 PostgreSQL 兼容,MySQL 也支持句法: LIMIT # OFFSET #。

mysql> SELECT * FROM table LIMIT 5,10;  // 检索记录行 6-15   
  
//为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1:    
mysql> SELECT * FROM table LIMIT 95,-1; // 检索记录行 96-last.   
  
//如果只给定一个参数,它表示返回最大的记录行数目:    
mysql> SELECT * FROM table LIMIT 5;     //检索前 5 个记录行   
  
//换句话说,LIMIT n 等价于 LIMIT 0,n。



MYSQL limit的优化
同样是取10条数据
select * from yanxue8_visit limit 10000,10  

select * from yanxue8_visit limit 0,10
就不是一个数量级别的。
1、offset比较小的时候。

select * from yanxue8_visit limit 10,10  


   多次运行,时间保持在0.0004-0.0005之间

Select * From yanxue8_visit Where vid >=(   
Select vid From yanxue8_visit Order By vid limit 10,1   
) limit 10  


  多次运行,时间保持在0.0005-0.0006之间,主要是0.0006
结论:偏移offset较小的时候,直接使用limit较优。这个显然是子查询的原因。

2、offset大的时候。


select * from yanxue8_visit limit 10000,10  


   //多次运行,时间保持在0.0187左右 


Select * From yanxue8_visit Where vid >=(   
Select vid From yanxue8_visit Order By vid limit 10000,1   
) limit 10  

//多次运行,时间保持在0.0061左右,只有前者的1/3。可以预计offset越大,后者越优。 
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics