更新时间:2022-06-13 GMT+08:00
动态调用匿名块
动态调用匿名块是指在动态语句中执行匿名块,使用EXECUTE IMMEDIATE…USING语句后面带IN、OUT来输入、输出参数。
语法
语法请参见图1。
using_clause子句的语法参见图2。
对以上语法格式的解释如下:
- 匿名块程序实施部分,以BEGIN语句开始,以END语句停顿,以一个分号结束。
- USING [IN|OUT|IN OUT] bind_argument,用于指定存放传递给存储过程参数值的变量。bind_argument前的修饰符与对应参数的修饰符一致。
- 匿名块中间的输入输出参数使用占位符来指明,要求占位符个数与参数个数相同,并且占位符所对应参数的顺序和USING中参数的顺序一致。
- 目前GaussDB(DWS)在动态语句调用匿名块时,EXCEPTION语句中暂不支持使用占位符进行输入输出参数的传递。
示例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
--创建存储过程dynamic_proc
CREATE OR REPLACE PROCEDURE dynamic_proc
AS
staff_id NUMBER(6) := 200;
first_name VARCHAR2(20);
salary NUMBER(8,2);
BEGIN
--执行匿名块
EXECUTE IMMEDIATE 'begin select first_name, salary into :first_name, :salary from staffs where staff_id= :dno; end;'
USING OUT first_name, OUT salary, IN staff_id;
dbms_output.put_line(first_name|| ' ' || salary);
END;
/
--调用存储过程
CALL dynamic_proc();
--删除存储过程
DROP PROCEDURE dynamic_proc;
|
父主题: 动态语句