LIMIT
和 OFFSET
#LIMIT
和 OFFSET
使您能够仅检索由查询其他部分生成的部分行
SELECTselect_list
FROMtable_expression
[ ORDER BY ... ] [ LIMIT {count
| ALL } ] [ OFFSETstart
]
如果给出了限制计数,则将返回的行的数量不会超过该计数(但如果查询本身产生较少数量的行,则可能会返回较少数量的行)。LIMIT ALL
与省略 LIMIT
子句相同,在 LIMIT
中使用 NULL 参数时也是如此。
OFFSET
表示在开始返回行之前跳过该数量的行。OFFSET 0
与省略 OFFSET
子句相同,在 OFFSET
中使用 NULL 参数时也是如此。
如果同时出现 OFFSET
和 LIMIT
,则在开始计算返回的 LIMIT
行数之前跳过 OFFSET
行。
在使用 LIMIT
时,务必使用 ORDER BY
子句将结果行约束为唯一顺序。否则,您将获得查询行的一个不可预测子集。您可能要求第十至第二十行,但第十至第二十行按什么顺序排列?除非您指定 ORDER BY
,否则顺序未知。
查询优化器在生成查询计划时考虑 LIMIT
,因此,您很可能针对 LIMIT
和 OFFSET
所提供的不同内容获得不同的计划(产生不同的行顺序)。因此,除非您通过 ORDER BY
执行可预测的结果排序,否则使用不同的 LIMIT
/OFFSET
值来选择查询结果的不同子集将产生不一致的结果。这不是一个缺陷;这是 SQL 不承诺提供查询结果的任何特定顺序这一事实的固有后果,除非使用 ORDER BY
约束该顺序。
由 OFFSET
子句跳过的行仍然必须在服务器内部计算;因此,较大的 OFFSET
可能会降低效率。