oracle function 怎么自动执行_Oracle数据库扩展语言PL/SQL之自治事务

点击蓝字关注我吧

【本文详细介绍了Oracle数据库扩展语言PL/SQL中自治事务的基本概念和使用方法,欢迎读者朋友们阅读、转发和收藏!】

在基于低版本的 Oracle 执行当前一个由多个 DML 组成的 transaction( 事务 ) 时 ,如果 为每一步 DML 记录一些信息到跟踪表中 , 由于事务的原子性 , 这些跟踪信息的提交将决定于主事务的 commit 或 rollback. 这样一来写程序的难度就增大了 , 程序员不得不把这些跟踪信息记录到类似数组的结构中 , 然后在主事务结束后把它们存入跟踪表。

为解决这个问题, ORACLE8i 新增了 AUTONOMOUS TRANSACTION( 自治事务,以下 AT) 。

AT 是由主事务 ( 以下 MT) 调用但是独立于它的事务。在 AT 被调用执行时, MT 被挂起,在 AT 内部,一系列的 DML 可以被执行并且 commit 或 rollback.

注意由于 AT 的独立性,它的 commit 和 rollback 并不影响 MT 的执行效果。在 AT 执行结束后,主事务获得控制权,又可以继续执行了。

实现 AT 的定义只需下列 PL/SQL 的声明部分加上 PRAGMAAUTONOMOUS_TRANSACTION 就可以了。

可以加自治事务的有:

1 . 顶级的匿名 PL/SQL 块

2 . Functions 或 Procedure (独立声明或声明在 package 中都可)

3 . SQL Object Type 的方法

4 . 触发器。

比如:

在一个独立的 procedure 中声明 AT

CREATE OR REPLACE PROCEDURELog_error(error_msg IN VARCHAR2(100))ISPRAGMA AUTONOMOUS_TRANSACTION;
BEGIN
Insert into Error_log values ( sysdate,error_msg);
COMMIT;
END;

运用 AT 时 , 有一些注意事项 , 简单列举如下 :

1. 在匿名 PL/SQL 块中 , 只有顶级的匿名 PL/SQL 块可以被设为 AT

2. 如果 AT 试图访问被 MT 控制的资源 , 可能有 deadlock 发生 .

3. Package 不能被声明为 AT, 只有 package 所拥有的 function 和 procedure 才能声明为 AT

4. AT 程序必须以 commit 或 rollback 结尾 , 否则会产生 Oracle 错误 ORA-06519: active autonomous transaction detected and rolled back

在日志记录,或者是重试计数等这样的场景中使用自治事物,可不用考虑主事物是否提交。

我知道你在看

2afd554a37092050bcbd0dae29b3446c.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值