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

华为GaussDB T 存储过程CREATE OR REPLACE PROCEDURE

原创 章芋文 2019-09-29
1464

创建一个新的存储过程。如果是CREATE OR REPLACE操作,在原对象已经存在情况下,为UPDATE操作,并不会重新创建。

存储过程/自定义函数/触发器(统称过程体)创建成功后,会通过全局序列OBJECT_ID$分配得到一个全局唯一的ID,该ID在系统表中唯一标识一个过程体。全局序列OBJECT_ID$从1000开始,递增为1。

系统初始化时创建了全局序列SEQ_PROC_001,该序列可为存储过程调用者提供唯一的序列号。该序列从30000开始,递增为1。

注意事项

存储过程和自定义函数共用同一张系统表,因此,注意避免存储过程和自定义函数重名,普通用户不可以创建系统用户对象。

创建存储过程需要以斜杠'/'作为结束标识符,包括匿名块、存储过程、自定义函数、触发器。

语法格式

CREATE [ OR REPLACE ] PROCEDURE [ IF NOT EXISTS ] [schema_name.]procedure_name(args_list)

  { IS | AS } 

  [ param_list ]

  BEGIN  

    statement;    

  END;

 /

参数说明

OR REPLACE

如果存储过程已经存在,替换原有的存储过程。

IF NOT EXIST

判断存储过程是否存在。

procedure_name

存储过程名。

schema_name

存储过程所有者。

args_list

参数列表。包含输入参数(in)、输出参数(out)和输入输出参数(in out)3中参数模式,每个参数可以选择其一,其中输入参数可以指定缺省值。

in是参数的默认模式,这种模式就是在程序运行的时候已经具有值,在程序体中值不会改变。

out模式定义的参数只能在过程体内部赋值,表示该参数可以将某个值传递回调用他的过程。

in out表示该参数可以向该过程中传递值,也可以将某个值传出去。

param_list

可以为空。声明的新变量及其缺省值。变量的声明语法请参见声明语法。

statement

存储过程语句。不允许为空,为空会报错。可以使用基本语句、动态语句、控制语句、异常语句或其他语句。基本语句详情请参见基本语句,动态语句详情请参见动态语句,控制语句详情请参见控制语句,其他语句详情请参见其他语句,自定义函数详情请参见自定义函数,自定义存储过程请参见创建存储过程。

示例

--删除重名的存储过程。
DROP PROCEDURE IF EXISTS Zenith_Test_003;
--删除重名的自定义函数。
DROP FUNCTION IF EXISTS Zenith_Test_003;
--创建存储过程。
CREATE OR REPLACE PROCEDURE Zenith_Test_003(param1 IN VARCHAR2,param2 IN VARCHAR2)
IS
BEGIN
     DBMS_OUTPUT.PUT_LINE('Hello Zenith:'||param1||','||param2);
END Zenith_Test_003;
/
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论