PRAGMA AUTONOMOUS_TRANSACTION自治事务

PRAGMA AUTONOMOUS_TRANSACTION

当前的存储过程作为已有事务的子事务运行,子事务的commit,rollback操作不影响父事务的状态

可以用于

(1)匿名块

(2)触发器

(3)存储过程

 如下:--------------------------------------------------------------------
procedure addRowAutonomous
(
  pID         in TLOG.id%type,
  pLDate      in TLOG.ldate%type,
  pLHSECS     in TLOG.lhsecs%type,
  pLLEVEL     in TLOG.llevel%type,
  pLSECTION   in TLOG.lsection%type,
  pLUSER      in TLOG.luser%type,
  pLTEXTE     in TLOG.ltexte%type
)
is
PRAGMA AUTONOMOUS_TRANSACTION;
begin
 addRow
  (
   pID         => pID,
   pLDate      => pLDate,
   pLHSECS     => pLHSECS,
   pLLEVEL     => pLLEVEL,
   pLSECTION   => pLSECTION,
   pLUSER      => pLUSER,
   pLTEXTE     => pLTEXTE
  );
  commit;
  exception when others then
      PLOG.ERROR;
      rollback;
      raise;
end;

在程序中,要注意一定要把事务控制好,不要有遗漏的地方,否则会有ORA-06519

 

阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/wonder4/article/details/786777
文章标签: exception 存储
个人分类: Oracle技术
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

PRAGMA AUTONOMOUS_TRANSACTION自治事务

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭