创建存储过程
功能描述
创建一个新的存储过程。如果是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进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。评论