云数据库 GAUSSDB-动态调用匿名块:语法

时间:2024-11-13 14:45:43

语法

动态调用匿名块语法如图1所示。

图1 call_anonymous_block::=

using_clause子句的语法如图2所示。

图2 using_clause::=

对以上语法格式的解释如下:

  • 匿名块程序实施部分,以BEGIN语句开始,以END语句停顿,以一个分号结束。
  • USING [IN|OUT|IN OUT] bind_argument,用于指定存放传递给存储过程参数值的变量。bind_argument前的修饰符与对应参数的修饰符一致。
  • 匿名块中间的输入输出参数使用占位符来指明,要求占位符个数与参数个数相同,并且占位符所对应参数的顺序和USING中参数的顺序一致。
  • 仅支持匿名块中调用SQL语句和存储过程时绑定参数,其余绑定参数场景皆不支持。例如:匿名块中使用表达式以及cursor等、匿名块中嵌套调用动态语句。
  • 不支持匿名块中SELECT INTO语句调用含有出参的FUNCTION/PROCEDURE时,绑定出参。
  • 不支持同一条语句同时使用匿名块内声明的变量和绑定参数。
  • 不支持绑定参数时使用PERFORM关键字调用存储过程。
  • 调用存储过程时,仅支持绑定参数直接作为出入参,不支持表达式形式(如“1+:va”)作为出入参,并且占位符名不能使用带引号的数字、字符或字符串。
  • IMMEDIATE关键字仅用作语法兼容,无实际意义。
  • 绑定入参类型为refcursor时,存储过程内的修改与入参相互隔离。
  • 打开dynamic_sql_check参数时,占位符个数与参数个数一致时使用同名占位符作为匿名块参数会报错,需修改为不同名参数,详见示例
support.huaweicloud.com/distributed-devg-v8-gaussdb/gaussdb-12-0780.html