LIMIT 和 OFFSET #LIMIT 和 OFFSET 允许您仅检索由查询的其余部分生成的部分行
SELECTselect_listFROMtable_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 给定的值。因此,使用不同的 LIMIT/ OFFSET 值来选择查询结果的不同子集,除非您使用 ORDER BY 强制执行可预测的结果顺序,将给出不一致的结果。这不是错误;这是 SQL 不承诺以任何特定顺序传递查询结果的固有结果,除非使用 ORDER BY 来约束顺序。
由 OFFSET 子句跳过的行仍然必须在服务器内部计算;因此,大的 OFFSET 可能会效率低下。
如果您在文档中发现任何不正确、与您特定功能的体验不符或需要进一步澄清的内容,请使用此表单报告文档问题。