自治事务
功能描述
自治事务作为一个独立的事务,不受调用它的自定义函数或者存储过程的影响 。存储过程支持自治事务,涵盖:存储过程、自定义函数、触发器以及匿名块。
注意事项
- 存储过程支持自治事务的嵌套调用,但最大嵌套层次有8层的限制。
- 在匿名块中使用自治事务,自治事务声明语句必须放在顶层匿名块中。同时,若匿名块中嵌套匿名块,自治事务声明语句只能出现在顶层匿名块中,内部匿名块不允许使用自治事务声明语句,否则报错。
- 自治事务最后必须要有commit或者rollback,否则报错。
- 自治事务内部目前不支持使用return result语句返回多结果集。
- 自治事务目前不支持游标作为出参返回。
语法格式
CREATE [ OR REPLACE ] PROCEDURE [ IF NOT EXISTS ] [schema_name.] procedure_name(args_list) IS PRAGMA AUTONOMOUS_TRANSACTION; [param-list] BEGIN statement; END; /
参数说明
- OR REPLACE
如果存储过程已经存在,替换原有的存储过程。
- IF NOT EXISTS
判断存储过程是否存在。
procedure_name
存储过程名。
schema_name
存储过程所有者。
args_list
参数列表。包含输入参数(in)、输出参数(out)和输入输出参数(in out)3中参数模式,每个参数可以选择其一,其中输入参数可以指定缺省值。
in是参数的默认模式,这种模式就是在程序运行的时候已经具有值,在程序体中值不会改变。
out模式定义的参数只能在过程体内部赋值,表示该参数可以将某个值传递回调用他的过程。
in out表示该参数可以向该过程中传递值,也可以将某个值传出去。
- PRAGMA AUTONOMOUS_TRANSACTION
自治事务声明语句。
- param-list
参数列表。可以指定参数的缺省值。格式为“variant_name data_type [ { := | DEFAULT } default_expr ];”。
- statement
匿名块语句,不允许为空,为空会报错。
可以使用基本语句、动态语句、控制语句、异常语句、其他语句、函数或存储过程。基本语句详情请参见基本语句,动态语句详情请参见动态语句,控制语句详情请参见控制语句,其他语句详情请参见其他语句,自定义函数详情请参见自定义函数,自定义存储过程请参见创建存储过程。
示例
创建自治事务。
--删除表AOPEN_CHARTSTAT_ERRLOG。 DROP TABLE IF EXISTS AOPEN_CHARTSTAT_ERRLOG;
--创建表AOPEN_CHARTSTAT_ERRLOG。 CREATE TABLE AOPEN_CHARTSTAT_ERRLOG ( USERDEFMSG VARCHAR(100), ORACODE VARCHAR(20), ORAMSG VARCHAR(500) );
--创建自治事务。 CREATE OR REPLACE PROCEDURE PRINT_CHARTSTAT_ERRLOG (USERDEFMSG IN VARCHAR2,ORACODE IN VARCHAR2,ORAMSG IN VARCHAR2) IS PRAGMA AUTONOMOUS_TRANSACTION; BEGIN INSERT INTO AOPEN_CHARTSTAT_ERRLOG (USERDEFMSG, ORACODE, ORAMSG) VALUES (USERDEFMSG, ORACODE, ORAMSG); COMMIT; END; /
--使用自治事务。 CALL AOPEN_CHARTSTAT_ERRLOG ('aaa', ‘01’, ‘success’);
「喜欢文章,快来给作者赞赏墨值吧」【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。评论