2025年9月25日: PostgreSQL 18 发布!
支持的版本: 当前 (18) / 17 / 16 / 15 / 14 / 13
开发版本: 开发版
不支持的版本: 12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1

DECLARE

DECLARE — 定义一个游标

概要

DECLARE cursor_name [ BINARY ] [ ASENSITIVE | INSENSITIVE ] [ [ NO ] SCROLL ] CURSOR [ { WITH | WITHOUT } HOLD ] FOR prepared_name
DECLARE cursor_name [ BINARY ] [ ASENSITIVE | INSENSITIVE ] [ [ NO ] SCROLL ] CURSOR [ { WITH | WITHOUT } HOLD ] FOR query

描述

DECLARE 为准备语句的结果集迭代声明一个游标。此命令的语义与直接的 SQL 命令 DECLARE 略有不同:后者执行一个查询并将结果集准备好以便检索,而此嵌入式 SQL 命令仅将一个名称声明为一个用于迭代查询结果集的“循环变量”,实际执行发生在使用 OPEN 命令打开游标时。

参数

cursor_name #

游标名称,区分大小写。它可以是 SQL 标识符或宿主变量。

prepared_name #

预备查询的名称,可以是 SQL 标识符或宿主变量。

query #

一个 SELECTVALUES 命令,它将提供游标要返回的行。

有关游标选项的含义,请参阅 DECLARE

示例

为查询声明游标的示例

EXEC SQL DECLARE C CURSOR FOR SELECT * FROM My_Table;
EXEC SQL DECLARE C CURSOR FOR SELECT Item1 FROM T;
EXEC SQL DECLARE cur1 CURSOR FOR SELECT version();

为预备语句声明游标的示例

EXEC SQL PREPARE stmt1 AS SELECT version();
EXEC SQL DECLARE cur1 CURSOR FOR stmt1;

兼容性

DECLARE 是 SQL 标准中指定的。

另请参阅

OPEN, CLOSE, DECLARE

提交更正

如果您在文档中发现任何不正确、与您对特定功能的经验不符或需要进一步澄清的内容,请使用 此表格 报告文档问题。