Oracle触发器

Oracle触发器

数据库触发器是一个与表相关联的、存储的PL/SQL程序。每当一个特定的数据操作语句(Insert,update,delete)在指定的表上发出时,Oracle自动地执行触发器中定义的语句序列。

l 数据确认

l 实施复杂的安全性检查

l 做审计,跟踪表上所做的数据操作等

l 数据的备份和同步

语句级触发器 :在指定的操作语句操作之前或之后执行一次,不管这条语句影响 了多少行 。

行级触发器(FOR EACH ROW) :触发语句作用的每一条记录都被触发。在行级触 发器中使用old和new伪记录变量, 识别值的状态。

语法:

CREATE [or REPLACE] TRIGGER 触发器名

{BEFORE | AFTER}

{DELETE | INSERT | UPDATE [OF 列名]}

ON 表名

[FOR EACH ROW [WHEN(条件) ] ]

declare

……

begin

PLSQL 块

End 触发器名

范例:插入员工后打印一句话“一个新员工插入成功”

createorreplacetriggertestTrigger

afterinsertonperson

declare

– local variables here

begin

dbms_output.put_line(‘一个员工被插入’);

endtestTrigger;

范例:不能在休息时间插入员工

createorreplacetriggervalidInsertPerson

beforeinsertonperson

declare

weekendvarchar2(10);

begin

selectto_char(sysdate,’day’)intoweekendfromdual;

ifweekendin(‘星期一’)then

raise_application_error(-20001, ‘不能在非法时间插入员工’);

endif;

endvalidInsertPerson;

当执行插入时会报错

在触发器中触发语句与伪记录变量的值
触发语句

:old

:new Insert

所有字段都是空(null)

将要插入的数据 Update

更新以前该行的值

更新后的值 delete

删除以前该行的值

所有字段都是空(null)

范例:判断员工涨工资之后的工资的值一定要大于涨工资之前的工资

createorreplacetriggeraddsal4p

beforeupdateofsalonmyemp

foreachrow

begin

if:old.sal >= :new.salthen

raise_application_error(-20002,’涨前的工资不能大于涨后的工资’);

endif;

end;

调用

updatemyemp tsett.sal = t.sal -1;

需求:使用序列,触发器来模拟mysql中自增效果

1. 创建序列

1、建立表

复制代码 代码如下:create table user

(

id number(6) not null,

name varchar2(30) not null primary key

)

2、建立序列SEQUENCE

代码如下:

create sequence user_seq increment by 1 start with 1 minvalue 1 maxvalue 9999999999999 nocache order;

2.创建自增的触发器

分析:创建一个基于该表的before insert 触发器,在触发器中使用刚创建的SEQUENCE。

代码如下:

create or replace trigger user_trigger

before insert on user

for each row

begin

select user_seq.nextval into:new.id from sys.dual ;

end;

3.测试效果

insert into itcastuser(name) values(‘aa’);

commit;

insert into itcastuser(name) values(‘bb’);

commit;


本作品采用知识共享署名 4.0 中国大陆许可协议进行许可,欢迎转载,但转载请注明来自御前提笔小书童,并保持转载后文章内容的完整。本人保留所有版权相关权利。

本文链接:https://royalscholar.cn/2017/05/17/Oracle触发器/

# Oracle

评论

Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×