2024年9月26日: PostgreSQL 17 发布!
支持的版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:devel
不支持的版本: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 标准中指定。

另请参阅

OPENCLOSEDECLARE

提交更正

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