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