Oracle触发器

触发器

满足特定事件时系统自动执行的命名块。主要用于实现一些比较复杂的完整性需求。

分类

DML触发器,DDL触发器,替代触发器,从数据库事件触发器。 DML触发器:在表上执行DML操作时自动触发。 创建DML触发器。

  1. 考虑四个方面:时间(before,after)、事件(insert,update,delete)、对象(表)、级别(语句级和行级)

  2. 三个谓词:inserting,updating,deleting。可以用于判断正在执行那个DML操作。

  3. 两个属性(行级触发器)::old,:new. :old.属性名。作用是获得某个属性更新前后的值。当其出现在when条件中时,省略冒号。

    1. insert::new

    2. update::old,:new

    3. delete::old

  4. (4)在DML触发器内部,不能之间或者间接使用事务处理语句(commit,rollback)

创建语法

create trigger create or replace trgger trigger_name before|after insert or update [of 列名,,] or delete on tablename [for each row] [when 条件] declare begin end;

例如

update emp set deptno=11 where deptno=20; --执行不成功

执行不成功的原因:外建的存在

解决办法:写一个触发器实现级联更新

create or replace trigger tri after update or delete on dept for each row -- 行级(若去掉则此触发器就成为了语句级触发器) begin  if updating then   update emp set deptno=:new.deptno where deptno=:old.deptno;  elsif deleting then   delete from emp where deptno=:old.deptno;  end if; end; /

创建一个行级触发器,记录对职务为CLERK的雇员工资的修改,且当修改幅度超过200时才进行记录,用 when条件限定触发器。

-- 日志表 create table log1 (id int primary key, name varchar2(20), dete1 date, even varchar2(20)); -- 序列 create sequence seq1; -- 创建触发器 create or replace trigger tri2 after update on emp for each row when (old.job='CLERK' and abs(new.sal-old.sal)>200) begin  insert into log1 values(seq1.nextval,user,sysdate,'update'); end; / -- update emp set sal=sal+199 where job='CLERK';select * from log1;update emp set sal=sal+201 where job='CLERK';select * from log1;

创建触发器,进行dept表的同步复制

create table dept_bak as select * from dept;create or replace trigger tri3 after insert or delete or update on dept for each row begin  if inserting then   insert into dept_bak values(:new.deptno,:new.dname,:new.loc);  elsif updating then   update dept_bak set deptno=:new.deptno,dname=:new.dname,loc=:new.loc where deptno=:old.deptno;  elsif deleting then   delete from dept where deptno=:old.deptno;  end if; end; /
  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

曹博Blog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值