Postgresql 中文操作指南
7.6. LIMIT and 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 子句来将结果行约束到唯一顺序。否则,您将获得查询行的不可预测子集。您可能会要求第十到第二十行,但在什么顺序排列下是第十到第二十行?除非您指定 ORDER BY,否则排序未知。
查询优化器在生成查询计划时考虑了 LIMIT,因此根据您为 LIMIT 和 OFFSET 提供的内容,您很可能会获得不同的计划(产生不同的行顺序)。因此,使用不同的 LIMIT/OFFSET 值选择查询结果 will give inconsistent results 的不同子集,除非您使用 ORDER BY 强制可预测的结果排序。这不是一个 bug;这是以下事实的固有结果:除非使用 ORDER BY 约束顺序,否则 SQL 并不保证按任何特定顺序提供查询结果。
由 OFFSET 子句跳过的行仍然必须在服务器内计算;因此,一个大的 OFFSET 可能是低效的。