• 两个经典的Oracle触发器示例 update delete 锁表问题


    http://blog.csdn.net/justdo2008/article/details/4137779

    http://xiaoxinshome.iteye.com/blog/139609

    SQL> CREATE TABLE T(ID NUMBER(18),MC VARCHAR2(20),DT DATE);

    表已创建。

    SQL> CREATE OR REPLACE TRIGGER TR_T
      2  AFTER DELETE ON T
      3  FOR EACH ROW
      4  DECLARE V_COUNT NUMBER;
      5  --PRAGMA AUTONOMOUS_TRANSACTION;
      6  BEGIN
      7     INSERT INTO T VALUES(:OLD.ID,:OLD.MC,SYSDATE);
      8     COMMIT;
      9  END TR_DEL_CABLE;
    10  /

    触发器已创建

    SQL> INSERT INTO T VALUES(1,'111111',SYSDATE);

    已创建 1 行。

    SQL> INSERT INTO T VALUES(2,'222222',SYSDATE);

    已创建 1 行。

    SQL> COMMIT;

    提交完成。

    SQL> SELECT ID,MC,TO_CHAR(DT,'YYYYMMDD HH24:MI:SS') FROM T;

            ID MC                   TO_CHAR(DT,'YYYYM
    ---------- -------------------- -----------------
             1 111111               20080802 11:07:36
             2 222222               20080802 11:07:43

    SQL> DELETE FROM T WHERE ID=1;
    DELETE FROM T WHERE ID=1
                *
    第 1 行出现错误:
    ORA-04091: 表 TEST.T 发生了变化, 触发器/函数不能读它
    ORA-06512: 在 "TEST.TR_T", line 4
    ORA-04088: 触发器 'TEST.TR_T' 执行过程中出错


    SQL> SELECT ID,MC,TO_CHAR(DT,'YYYYMMDD HH24:MI:SS') FROM T;

            ID MC                   TO_CHAR(DT,'YYYYM
    ---------- -------------------- -----------------
             1 111111               20080802 11:07:36
             2 222222               20080802 11:07:43

    SQL> CREATE OR REPLACE TRIGGER TR_T
      2  AFTER DELETE ON T
      3  FOR EACH ROW
      4  DECLARE V_COUNT NUMBER;
      5  PRAGMA AUTONOMOUS_TRANSACTION;
      6  BEGIN
      7     INSERT INTO T VALUES(:OLD.ID,:OLD.MC,SYSDATE);
      8     COMMIT;
      9  END TR_DEL_CABLE;
    10  /

    触发器已创建

    SQL> DELETE FROM T WHERE ID=1;

    已删除 1 行。

    SQL> COMMIT;

    提交完成。

    SQL> SELECT ID,MC,TO_CHAR(DT,'YYYYMMDD HH24:MI:SS') FROM T;

            ID MC                   TO_CHAR(DT,'YYYYM
    ---------- -------------------- -----------------
             2 222222               20080802 11:07:43
             1 111111               20080802 11:08:32

  • 相关阅读:
    奥运圣火在家乡传递
    Please stop reinventing the wheel (请不要重复发明轮子)
    使用IDispatch::Invoke函数在C++中调用C#实现的托管类库方法
    To invoke and to begin invoke, that is a question.
    XML和JSON(JavaScript Object Notation)
    Cloud Computing Is a Big Whiteboard
    TRIE Data Structure
    ASP.NET AJAX UpdatePanel 控件实现剖析
    分布式计算、网格计算和云计算
    系统架构设计师考试大纲(2009版)
  • 原文地址:https://www.cnblogs.com/daojian/p/2616634.html
Copyright © 2020-2023  润新知