MySQL的limit用法及优化(转)

常规用法:

用法一:

SELECT `keyword_rank`.* FROM `keyword_rank` WHERE (advertiserid=‘59‘) LIMIT 2 OFFSET 1;

比如这个SQL ,limit后面跟的是2条数据,offset后面是从第1条开始读取。

用法二:

SELECT `keyword_rank`.* FROM `keyword_rank` WHERE (advertiserid=‘59‘) LIMIT 2,1;

而这个SQL,limit后面是从第2条开始读,读取1条信息。

用法三:

select * from tablename <条件语句> limit 100,-1

从第100条后开始-最后一条的记录。

用法四:

select * from tablename <条件语句> limit 15

相当于limit 0,15,查询结果取前15条数据

用法五:

MySQL低版本不支持limit offset

limit offset在MySQL 4.0以上的版本中都可以正常运行,在旧版本的MySQL 3.23中无效

limit m offset n等价于limit m,n

limit的优化:

MySQL的limit给分页带来了极大的方便,但数据量一大的时候,limit的性能就急剧下降

MySQL的优化是非常重要的。其他最常用也最需要优化的就是limit。MySQL的limit给分页带来了极大的方便,但数据量一大的时候,limit的性能就急剧下降。

同样是取10条数据

select * from yanxue8_visit limit 10000,10 

select * from yanxue8_visit limit 0,10

就不是一个数量级别的。

网上也很多关于limit的五条优化准则,都是翻译自MySQL手册,虽然正确但不实用。今天发现一篇文章写了些关于limit优化的,很不错。

文中不是直接使用limit,而是首先获取到offset的id然后直接使用limit size来获取数据。根据他的数据,明显要好于直接使用limit。这里我具体使用数据分两种情况进行测试。

(测试环境CentOS 6+P4双核(3GHZ)+4G内存 MySQL 5.0.19)

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越大,后者越优。

参考:

http://www.jb51.net/article/41759.htm(以上内容转自此篇文章)

http://www.jb51.net/article/85312.htm

http://www.cnblogs.com/lisqiong/p/5635009.html

http://blog.csdn.net/cug_jiang126com/article/details/42246721

http://www.cnblogs.com/beynol/p/mysql-optimization-limit.html

时间: 2025-01-13 19:15:28

MySQL的limit用法及优化(转)的相关文章

MYSQL中LIMIT用法

MYSQL中LIMIT用法 SELECT * FROM tableName LIMIT [offset,] rows; 1.select * from table limit m,n(显示条数) 其中m是指记录开始的索引index(索引是从0开始的表示第一条记录 ) n是指从第m+1条开始,取n条. 结果是检索记录第m+1行至(m+n)行记录,共取出n条记录 ex: SELECT * FROM 表名 limit 6,5; 结果:检索记录第7行至11行记录,共取出5条记录. 2.n可以被设置为-1

sqlserver row_number 类似 mysql中 limit 用法

select * from ( select row_number() over(ORDER BY inspecdate desc,inspectime DESC,itemorder asc ) as num, contentid,quesioncontext,tempid,tempname,itemid,itemtext,belongteam,teamname,inspecdate, inspectime,contenttext,createperson,newaddtime,updateti

MySQL的LIMIT与分页优化

在系统中需要进行分页操作的时候,我们通常会使用LIMIT加上偏移量的办法实现,同时加上合适的ORDER BY子句.如果有对应的索引,通常效率会不错,否则,MySQL需要做大量的文件排序操作. 一个非常常见又令人头疼的问题就是,在偏移量非常大的时候,例如可能是LIMIT 10000,20这样的查询,这时MySQL需要查询10020条记录后只返回最后20条,前面10000条记录都将被抛弃,这样的代价非常高.如果所有的页面被访问的频率都相同,那么这样的查询平均需要访问半个表的数据.要优化这种查询,要么

MYSQL 中 LIMIT 用法

mapper文件中的sql: -------------------------------------------------------------------------------------------- (在实体类中定义的属性) start:从第几条记录开始. size:读取几条记录. select id="findAllUsers" parameterType="Map" resultType="entity.IUser">

[笔记]MySQL的LIMIT用法

limit是mysql提供的分页语句 1 SELECT * FROM table LIMIT offset, page_size 例如 SELECT * FROM articals WHERE cid = 1 ORDER BY id LIMIT 50, 10

Mysql的limit用法

limit可以用来显示从m条记录开始的n条记录,具体语句如下: select * from table_test limit 0,10;    #显示从0开始的10条记录(表中的第一条记录下标为0) select * from core_stocknum_169 limit 10,10:    #显示从11开始的10条记录(11-20)

Mysql中limit用法及简单按序查寻示例

limit 接收一个或两个参数. 可以实现前排前几行的数据或排后几行的数据,或者中间几行的数据 order by + 关键字  表示按关键字什么顺序排列,默认是正序,从小到大, order by + 关键字 desc 表示按倒序排列,从大到小顺序. 如:倒序排列取前几行数据: order by id desc limit 10 按照id的倒序排序 取出前10条 order by id desc limit 0,10 按照id的倒序排序 取出前10条 换句话说,Limit n 等价于 Limit

Mysql 分页语句Limit用法

转载自:http://qimo601.iteye.com/blog/1634748 1.Mysql的limit用法 在我们使用查询语句的时候,经常要返回前几条或者中间某几行数据,这个时候怎么办呢?不用担心,mysql已经为我们提供了这样一个功能. Sql代码   SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数.LIMIT 接受一个或两个数字参数.参数必须

MYSQL LIMIT 用法详解

在mysql的limit用法中,网上有这样的论述: "//为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1: mysql> SELECT * FROM table LIMIT 95,-1; // 检索记录行 96-last. " 写这句话的人自己肯定没有实际去操作,因为这是不对的. You have an error in your SQL syntax; check the manual that corresponds to your MySQL