OFFSET FETCH 子句
OFFSET 和 FETCH 可用于按批次检索数据。它们用于指定希望通过单条查询获取的一段行数据。
offset_row_count 或 fetch_row_count 的值可以是数字或字面常量。可以省略 fetch_row_count;默认情况下,它为 1。
OFFSET 指定在开始返回查询结果集中的行之前需要跳过的行数。OFFSET n 会跳过结果中的前 n 行。
支持负值 OFFSET:OFFSET -n 会跳过结果中的最后 n 行。
也支持小数形式的 OFFSET:OFFSET n —— 如果 0 < n < 1,则跳过结果中前 n * 100% 的部分。
示例:
• OFFSET 0.1 —— 跳过结果的前 10%。
注意 • 该小数必须是一个 Float64 类型的数字,小于 1 且大于 0。 • 如果根据计算得到的是一个小数行数,则向上取整为下一个整数。
FETCH 指定查询结果中最多可以包含的行数。
ONLY 选项用于返回紧跟在 OFFSET 所跳过的行之后的行。在这种情况下,FETCH 是 LIMIT 子句的替代方案。例如,下面的查询
与下列查询完全等价
WITH TIES 选项用于根据 ORDER BY 子句,在结果集中返回所有与“最后一名”并列的额外行。例如,如果 fetch_row_count 设置为 5,但又有两行与第 5 行在 ORDER BY 列上的值相同,那么结果集中将包含 7 行。
注意
根据标准,当两者同时存在时,OFFSET 子句必须位于 FETCH 子句之前。
注意
实际偏移量也可能取决于 offset 设置。
示例
输入表:
ONLY 选项的用法:
结果:
WITH TIES 选项的使用方法:
结果: