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

华为GaussDB T 自治事务

墨天轮 2019-10-12
854

自治事务

功能描述

自治事务作为一个独立的事务,不受调用它的自定义函数或者存储过程的影响 。存储过程支持自治事务,涵盖:存储过程、自定义函数、触发器以及匿名块。

注意事项

  • 存储过程支持自治事务的嵌套调用,但最大嵌套层次有8层的限制。
  • 在匿名块中使用自治事务,自治事务声明语句必须放在顶层匿名块中。同时,若匿名块中嵌套匿名块,自治事务声明语句只能出现在顶层匿名块中,内部匿名块不允许使用自治事务声明语句,否则报错。
  • 自治事务最后必须要有commit或者rollback,否则报错。
  • 自治事务内部目前不支持使用return result语句返回多结果集。
  • 自治事务目前不支持游标作为出参返回。

语法格式

CREATE [ OR REPLACE ] PROCEDURE [ IF NOT EXISTS ] [schema_name.] procedure_nameargs_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进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论