暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

GaussDB数据库-嵌入式SQL命令:PREPARE

CY 学数据库 2023-10-19
75

功能描述

准备用于执行的语句。

语法格式

PREPARE name FROM string

参数说明

  • name

    预备查询标识符。

  • string

    包含预备语句的文本C字符串或者宿主变量,预备语句包含SELECT,INSERT,UPDATE或者DELETE命令之一。

示例

char *stmt = "SELECT * FROM test1 WHERE a = ? AND b = ?";
EXEC SQL ALLOCATE DESCRIPTOR outdesc;
EXEC SQL PREPARE foo FROM :stmt;
EXEC SQL EXECUTE foo USING SQL DESCRIPTOR indesc INTO SQL DESCRIPTOR outdesc;

须知:

ecpg提供的prepare语句不直接等同于内核提供的prepare语法,举例如下:

GaussDB Kernel内核语法:

PREPARE name [ ( data_type [, ...] ) ] AS statement

嵌入式SQL语句:

EXEC SQL PREPARE I(int, int) AS INSERT INTO T VALUES ( $1, $2 );
EXEC SQL EXECUTE I(1, 2);

执行上述语句出现报错时,提示too few arguments on。ecpg提供动态SQL解决PREPARE name [ ( data_type [, ...] ) ] AS statement语法场景的使用。

利用动态sql语法规则解决上述问题:

EXEC SQL PREPARE I(int, int) AS INSERT INTO T VALUES ( $1, $2 );
EXEC SQL EXECUTE I(1, 2);
EXEC SQL EXECUTE I using 1, 2;EXEC SQL PREPARE I AS INSERT INTO T VALUES ( $1, $2 );
EXEC SQL EXECUTE I using 1, 2;
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论