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

华为GaussDB T 执行存储过程CALL | EXEC PROCEDURE

原创 章芋文 2019-09-28
4726

注意事项

自定义存储过程和系统函数重名时,数据库会优先调用系统函数。如果需要优先调用重名的自定义存储过程,则需要将该自定义存储过程配置在$GSDB_DATA/cfg/udf.ini中,格式为user_name.procedure_name,配置完成后,需要重启数据库,配置才会生效。

udf.ini文件的权限应设置为只有数据库用户组dbgrp中的用户有权限修改,权限为600。

执行存储过程时,可以指定参数列表中所有参数的值,也可以使用“=>”指定部分参数的值。指定部分参数值时,如果存在既没有缺省值也没有指定值的参数会报错。

执行存储过程时,不允许使用常量对IN OUT类型和OUT类型的输入参数赋值。

执行存储过程时,建议用户发现行号报错的时候查看SYS_PROCS视图来对应行号。

执行不带参数的存储过程(包括自定义函数),可以直接给定存储过程名或自定义函数名,不需要带括号。

执行存储过程时,可以用分号“;”作为结束符,或者直接换行使用“/”作为结束符;但不能两个结束符一起使用,如果一起使用会报错。


语法格式

{ CALL | EXEC } [schema_name.]procedure_name[(param[,...])];

参数说明

CALL

执行存储过程指令。

EXEC

执行存储过程指令。

schema_name

存储过程所有者。

procedure_name

存储过程名称。

param

存储过程参数,如果编译的存储过程不带参数,执行时可以不加括号。


示例

使用不带参数的存储过程。

--为存储过程案例准备基础表。
--删除重名的临时表。
DROP TABLE IF EXISTS table_temp;
--创建临时表。
CREATE TABLE table_temp(f1 INT, f2 VARCHAR2(20));
存储过程和函数存储在同一个系统表中,如果新创建的存储过程和已有自定义函数重名,将导致创建存储过程失败。因此,在创建存储过程之前,需要删除重名的自定义函数。
--删除重名的自定义函数。
DROP FUNCTION IF EXISTS p_no_param;
--删除重名的存储过程。
DROP PROCEDURE IF EXISTS p_no_param;
创建存储过程时,最后的“/”符号用于标示存储过程定义语句的结束,不能省略,且必须单独成行。
--创建一个不带参数的存储过程。
CREATE OR REPLACE PROCEDURE p_no_param IS 
BEGIN  
INSERT INTO table_temp VALUES(1,'xxx');  
COMMIT;
END;
/
--使用CALL执行存储过程。
CALL p_no_param; 
--使用EXEC执行存储过程。
EXEC p_no_param;
--检查临时表数据。
SELECT * FROM table_temp;

F1           F2
------------ --------------------
1            xxx
1            xxx

2 rows fetched.
--删除存储过程。
DROP PROCEDURE p_no_param;


使用带IN模式参数的存储过程。

--为存储过程案例准备基础表。
--删除重名的临时表。
DROP TABLE IF EXISTS table_temp;
--创建临时表。
CREATE TABLE table_temp(f1 INT, f2 INT, f3 VARCHAR2(20));

存储过程和函数存储在同一个系统表中,如果新创建的存储过程和已有自定义函数重名,将导致创建存储过程失败。因此,在创建存储过程之前,需要删除重名的自定义函数。

--删除重名的自定义函数。
DROP FUNCTION IF EXISTS p_with_param;
--删除重名的存储过程
DROP PROCEDURE IF EXISTS p_with_param;

创建存储过程时,最后的“/”符号用于标示存储过程定义语句的结束,不能省略,且必须单独成行。

--创建存储过程,第一个参数和第二个参数均有默认值0,第三个参数没有默认值。
CREATE OR REPLACE PROCEDURE p_with_param(param1 INT := 0, param2 INT DEFAULT 0,param3 VARCHAR2) IS
  BEGIN  
       INSERT INTO table_temp VALUES(param1,param2,param3);  
  COMMIT;
END;
/
--执行存储过程时指定全部输入参数的值。
--使用CALL执行存储过程。
CALL p_with_param(1,1,'xxx'); 
--使用EXEC执行存储过程。
EXEC p_with_param(1,1,'xxxx');

指定部分参数的值时,需要为所有没有默认值的参数指定值。如果一个参数既没有默认值,也没有指定值,则会返回错误。

--执行存储过程时,只为没有默认值的参数指定值。
--使用CALL执行存储过程。
CALL p_with_param(param3=>'yyy');
--使用EXEC执行存储过程。
EXEC p_with_param(param3=>'yyyy');
--查询临时表数据。
SELECT * FROM table_temp;

F1           F2           F3
------------ ------------ --------------------
1            1            xxx
1            1            xxxx
0            0            yyy
0            0            yyyy

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

评论