满足特定事件时系统自动执行的命名块。主要用于实现一些比较复杂的完整性需求。
分类
DML触发器,DDL触发器,替代触发器,从数据库事件触发器。 DML触发器:在表上执行DML操作时自动触发。 创建DML触发器。
三个谓词:inserting,updating,deleting。可以用于判断正在执行那个DML操作。
两个属性(行级触发器)::old,:new. :old.属性名。作用是获得某个属性更新前后的值。当其出现在when条件中时,省略冒号。
insert::new
update::old,:new
delete::old
(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; /