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 来实现分页。
相关推荐
Lotus_滴滴10 小时前
【金融保研复习】知识点与可能的题目
数据库
学习2年半11 小时前
sql题目
数据库·sql
还是奇怪11 小时前
SQL 注入攻防:绕过注释符过滤的N种方法
数据库·sql·web安全
Run Freely93711 小时前
MySqL-day4_03(索引)
数据库·mysql
编程充电站pro11 小时前
聚合函数陷阱:AVG 和 GROUP BY 搭配使用注意点
数据库·sql
会开花的二叉树12 小时前
实战:基于 BRPC+Etcd 打造轻量级 RPC 服务 —— 从注册到调用的完整实现
网络·数据库·c++·rpc·etcd
修炼果12 小时前
为什么使用 Redis 存储Oauth的state 参数,可有效防止 CSRF 攻击
数据库·redis·csrf
cookqq12 小时前
MongoDB源码delete分析观察者getOpObserver()->onDelete
数据库·sql·mongodb·nosql
曼曼青青草12 小时前
智能体介绍及搭建实战(智能运营)
大数据·数据库·人工智能
荷兰小香猪_0112 小时前
MongoDB数据类型与python操作
数据库·mongodb