Trigger触发器

本文介绍了一个Oracle数据库中的触发器实现案例,包括语句级和行级触发器的创建及使用。通过具体代码演示如何记录对emp表进行insert、update、delete操作时的变化,并将相关信息保存到另一个表BB中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

 

 

/**
语句级触发器,能同时被insert、update、delete触发,记录到表中:
触发时记录什么动作发生在emp表上,是否修改了ename列以及是否修改了empno列**/
CREATE OR REPLACE TRIGGER tri_dml_emp
  BEFORE insert or update OF ENAME, EMPNO or delete on emp
DECLARE
  V_TYPE VARCHAR2(10);
  V_DESC VARCHAR2(100);
BEGIN
  IF INSERTING THEN
    V_TYPE := 'INS';
  ELSIF UPDATING THEN
    V_TYPE := 'UPD';
  ELSIF DELETING THEN
    V_TYPE := 'DEL';
  END IF;
  IF UPDATING('EMPNO') THEN
    V_DESC := '更新EMPNO';
  ELSE
    V_DESC := '没有更新EMPNO';
  END IF;
  IF UPDATING('ENAME') THEN
    V_DESC := '更新ENAME';
  ELSE
    V_DESC := '没有更新ENAME';
  END IF;
  INSERT INTO BB VALUES (V_TYPE, V_DESC);
END TRI_DML_EMP;


/**编写一个行级触发器,能同时被insert、update、delete触发,记录到表中:
  触发时记录什么动作发生在emp表上,是否修改了ename列以及是否修改了empno列
  如果修改了ename列,请记录修改前和修改后的值**/
CREATE OR REPLACE TRIGGER dml_emp
  BEFORE insert or update OF ENAME, EMPNO or delete on emp
  FOR EACH ROW
DECLARE
  V_TYPE VARCHAR2(10);
  V_DESC VARCHAR2(100);
BEGIN
  IF INSERTING THEN
    V_TYPE := 'INS';
  ELSIF UPDATING THEN
    V_TYPE := 'UPD';
  ELSIF DELETING THEN
    V_TYPE := 'DEL';
  END IF;
 
  IF UPDATING('ENAME') THEN
    V_DESC := '更新ENAME,原ENAME=' || :OLD.ENAME || '  新ENAME=' || :NEW.ENAME;
  ELSE IF UPDATING('EMPNO') THEN
     V_DESC := '更新EMPNO,原EMPNO=' || :OLD.EMPNO || '  新EMPNO=' || :NEW.EMPNO;
     ELSE 
    V_DESC := '没有更新';
  END IF;
  END IF;
  
  INSERT INTO BB VALUES (V_TYPE, V_DESC);
END DML_EMP;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值