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