• 《oracle每天一练》触发器不能调用或间接调用COMMIT,ROLLBACK等DCL语句


    触发器不能调用或间接调用COMMIT,ROLLBACK等DCL语句  

    在触发器中不能运行 ddl语句和commit,rollback语句

    ddl语句:DDL语句用语定义和管理数据库中的对象,如Create,Alter,Drop,truncate等;DDL操作是隐性提交的!
             操作立即生效,原数据不放到rollback segment中,不能回滚. 操作不触发trigger

    DML(Data Manipulation Language)数据操纵语言命令使用户能够查询数据库以及操作已有数据库中的数据。
    如insert,delete,update,select等都是DML.

           触发器是无需commit的,而且也不能写commit;触发器和触发它的DML是同一个事务DML提交了,触发器的操作也提交了,所以无需Commit;否则就会造成错误信息。当然,如果你一定要在触发器里写COMMIT,那也是可以的,可以用Oracle中的自治事务来处理,自治事务就相当于一个事务里的子事务。
          在正常情况下,Oracle规定在触发器中不能运行 DDL(即Create/Alter/Drop)语句和Commit/Rollback语句的,因为DDL操作是隐性提交的,在触发器不允许有Commit,如在触发器中加入DDL语句,这种隐性提交就会导致错误信息;但有时特殊情况下需要在触发器中使用DDL语句,这时怎么办。 
    可以采取以下的解决办法: 
    1.在可以在触发器中加入:pragma autonomous_transaction;(在DECLARE后面) 表示是自由事务处理。
    如: 
    CREATE OR REPLACE TRIGGER T_create BEFORE insert ON T_Tax_INS_BD
    for each row
    DECLARE
    pragma autonomous_transaction; 
    NRDSId varchar(500):=''; 
    begin 
    通过以上方法即可解决触发器中不能有DDL语句的问题!

    一:  在触发器中使用DDL语句。 如 drop table t1 ,触发的时候会报错,
    ORA-04092: cannot COMMIT in a trigger,因为DDL语句隐含commit。

    二: 触发器的主体中使用了commit或rollback等DCL语句。ORA-04092:
    cannot COMMIT in a trigger , 因为DML(delete/update/insert)触发器中
    不能使用DDL(CREATE,DROP,ALTER)语句,也不能使用事务控制语句(DCL)
    (ROLLBACK, COMMIT,SAVEPOINT)。特别注意的是,在触发器的主体中引用的
    函数(function)/过程(procedure)中也不能有事物控制语句。

    三: 注意: 系统级触发器(System Triggers)中可以使用DDL语句。

    四: 处理方法: 去掉事务控制语句;如果procedure中必须有commit,那么可以
    将commit 拿掉,由外部控制 。
  • 相关阅读:
    【雕爷学编程】Arduino动手做(102)TM1638按键数码管
    【雕爷学编程】Arduino动手做(103)四路无线遥控套件
    【昊泽爷爷】六一儿童节的礼物——学做简单机器人的工作台
    使用sourcegraph实现高效全局代码仓库搜索
    小程序模糊效果,兼容安卓,iOS
    软件测试阶段划分,各阶段测试的对象
    js执行机制
    【vue3】初探一
    linux设置默认PHP版本
    python下载大文件列表,断点续传,跳过已下载,显示下载进度
  • 原文地址:https://www.cnblogs.com/abc8023/p/5434569.html
Copyright © 2020-2023  润新知