MySQL 中LIMIT 的用法详解

MySQL 中LIMIT 的用法详解,第1张

在使用查询语句的时候,经常要返回前几条或者中间某几行的数据。在MySQL提供关键字LIMIT 来解决该类查询问题。

LIMIT 使用语法:

其中m是指记录开始的index,从0(下标0)开始,表示第一条记录

n是指从第m+1条开始,取n条记录。

即:取出第3条至第6条,总共4条记录,即检索记录行 3-6

LIMIT n 等价于 LIMIT 0,n。

只给定一个参数,它表示返回最大的记录行数目:

即:检索前 5 个记录行

检索从指定开始记录到记录集的结束所有的记录行,可以指定第二个参数为 -1

LIMIT m,-1

检索记录行 11-last.

limit x, y:表示跳过x个数据读取y个数据

limit x offset y:表示跳过y个数据读取x个数据,offset表示偏移量

limit x:表示从头开始读取x个数据,相当于limit 0,x

SELECT

*

FROM

表名

limit

m,n

SELECT

*

FROM

table

LIMIT

[offset,]

rows

1.m代表从m+1条记录行开始检索,n代表取出n条数据。(m可设为0)

如:SELECT

*

FROM

表名

limit

6,5

表示:从第7条记录行开始算,取出5条数据

2.值得注意的是,n可以被设置为-1,当n为-1时,表示从m+1行开始检索,直到取出最后一条数据。

如:SELECT

*

FROM

表名

limit

6,-1

表示:取出第6条记录行以后的所有数据。

3.若只给出m,则表示从第1条记录行开始算一共取出m条

如:SELECT

*

FROM

表名

limit

6

表示:取出前6条记录行。

4.根据数据量的大小选择相应的语句:

a.offset比较小:

SELECT

*

FROM

aff

limit

10,10

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

SELECT

*

FROM

aff

Where

vid

>=(

SELECT

vid

From

aff

Order

By

vid

limit

10,1

)

limit

10

多次运行,时间保持在0.0005-0.0006之间,主要是0.0006

结论:偏移量offset较小的时候,直接使用limit较优。这个显示是子查询的原因。

b.offset大的时候。

SELECT

*

FROM

aff

limit

10000,10

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

SELECT

*

FROM

aff

Where

vid

>=(

SELECT

vid

FROM

aff

Order

By

vid

limit

10000,1

)

limit

10

多次运行,时间保持在0.0061左右,只有前者的1/3。

结论:偏移量offset越大,后者越优。

总结

以上所述是小编给大家介绍的mysql中的limit用法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/8692861.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-20
下一篇 2023-04-20

发表评论

登录后才能评论

评论列表(0条)

保存