PostgreSQL(1) FETCH用法

摘要

在本教程中,您将学习如何使用 PostgreSQL 的 FETCH 子句来只检索查询结果中的一部分行。

SELECT 语句中,如果要跳过若干行并仅取回指定数量的行,通常会使用 LIMIT 子句。

LIMIT 子句被 MySQL、H2、HSQLDB 等许多关系型数据库管理系统广泛使用。然而,LIMIT 并不是 SQL 标准的一部分。

为了符合 SQL 标准,PostgreSQL 支持 FETCH 子句:可以先跳过一定数量的行,然后再取回指定数量的行。

注意:FETCH 子句是在 SQL 标准的 SQL:2008 中引入的。

语法

复制代码
OFFSET row_to_skip { ROW | ROWS }
FETCH { FIRST | NEXT } [ row_count ] { ROW | ROWS } ONLY

说明:

  • 首先在 OFFSET 关键字后指定要跳过的行数 row_to_skip。它是一个大于或等于 0 的整数,默认值为 0(即不跳过任何行)。
  • 如果 row_to_skip 大于表中的总行数,查询将返回 0 行。
  • 其次在 FETCH 子句中提供要取回的行数 row_countrow_count 必须是大于或等于 1 的整数,默认值为 1。
  • ROWROWS 的同义词,FIRSTNEXT 的同义词,二者可以互换使用。
  • 由于表中行的物理存储顺序未定义,应始终配合 ORDER BY 使用 FETCH 子句,以确保行的顺序一致。
  • 在 SQL:2008 中,OFFSET 必须位于 FETCH 之前;但在 PostgreSQL 中,OFFSETFETCH 的先后顺序可以任意。
  • FETCH 在功能上等价于 LIMIT。如果希望应用更符合其他数据库系统的标准实现,建议使用遵循标准 SQL 的 FETCH 子句。

示例

下面使用 sample database 中的 film 表进行演示。

以下查询使用 FETCH 子句,按标题升序选择第一条影片记录:

sql 复制代码
SELECT
    film_id,
    title
FROM
    film
ORDER BY
    title
FETCH FIRST ROW ONLY;

输出:

复制代码
 film_id |      title
---------+------------------
       1 | Academy Dinosaur
(1 row)

这等价于:

sql 复制代码
SELECT
    film_id,
    title
FROM
    film
ORDER BY
    title
FETCH FIRST 1 ROW ONLY;

以下查询使用 FETCH 子句,按标题升序选择前五条影片记录:

sql 复制代码
SELECT
    film_id,
    title
FROM
    film
ORDER BY
    title
FETCH FIRST 5 ROW ONLY;

输出:

复制代码
 film_id |      title
---------+------------------
       1 | Academy Dinosaur
       2 | Ace Goldfinger
       3 | Adaptation Holes
       4 | Affair Prejudice
       5 | African Egg
(5 rows)

下面的语句在按标题升序的基础上,跳过前五条记录后再取回接下来的五条记录:

sql 复制代码
SELECT
    film_id,
    title
FROM
    film
ORDER BY
    title
OFFSET 5 ROWS
FETCH FIRST 5 ROW ONLY;

输出:

复制代码
 film_id |      title
---------+------------------
       6 | Agent Truman
       7 | Airplane Sierra
       8 | Airport Pollock
       9 | Alabama Devil
      10 | Aladdin Calendar
(5 rows)

要点

  • 使用 PostgreSQL 的 FETCH 子句,可以跳过一定数量的行并取回指定数量的行。您可与 ORDER BY 搭配来确保结果顺序一致,必要时也可用 OFFSET 来实现分页。
相关推荐
倔强的石头_17 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐5 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再5 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest5 天前
数据库SQL学习
数据库·sql