支持的版本:当前 (17) / 16 / 15 / 14 / 13
开发版本:devel
不支持的版本: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 标准中指定。

另请参见

OPENCLOSEDECLARE

提交更正

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