[oracle] oracle触发器中的after和before有什么区别 , 语句级触发和行级触发有什么区别

after和before区别:
一个是在记录操作之前触发,一个是在记录操作之后触发。

比如表之间定义的有外键,在删除主键时,必须要先删除外键表,这时就有先后之分。

 

语句级触发和行级触发区别:

语句级别触发器只触发一次、行级触发器是作用了多少行触发多少次。
如果定义为语句级,则Delete     from   t执行时,触发器只运行一次,

如果定义为行级,则上面的Delete操作将使触器运行多次(有几条记录就运行几次)。

 

 

上面是 最简单的区别,当然还有其他的区别

触发顺序上有所区别
  语句级别触发器before
  行级别触发器before
  行级别触发器after
  语句级别触发器after

[TEST@ora10gr1#2009-12-18/21:08:09] SQL>create or replace trigger t1_triger_before
 
2  before insert on t1
 
3  begin
 
4      dbms_output.put_line('语句级别触发器before');
 
5  end;
 
6  /

Trigger created.

[TEST@ora10gr1#2009-12-18/21:08:09] SQL>create or replace trigger t1_triger_after
 
2  after insert on t1
 
3  begin
 
4      dbms_output.put_line('语句级别触发器after');
 
5  end;
 
6  /

Trigger created.

[TEST@ora10gr1#2009-12-18/21:08:09] SQL>create or replace trigger t1_triger_before_each_row
 
2  before insert on t1 for each row
 
3  begin
 
4      dbms_output.put_line('行级别触发器before');
 
5  end;
 
6  /

Trigger created.

[TEST@ora10gr1#2009-12-18/21:08:09] SQL>create or replace trigger t1_triger_after_each_row
 
2  after insert on t1 for each row
 
3  begin
 
4      dbms_output.put_line('行级别触发器after');
 
5  end;
 
6  /

Trigger created.

[TEST@ora10gr1#2009-12-18/21:08:09] SQL>
[TEST@ora10gr1#2009-12-18/21:08:09] SQL>set serveroutput on
[TEST@ora10gr1#2009-12-18/21:08:09] SQL>--注意触发顺序
[TEST@ora10gr1#2009-12-18/21:08:09] SQL>insert into t1 values(1,'a');
语句级别触发器before
行级别触发器before
行级别触发器after
语句级别触发器after

1 row created.

[TEST@ora10gr1#2009-12-18/21:08:09] SQL>--注触发发次数
[TEST@ora10gr1#2009-12-18/21:08:09] SQL>insert into t1
 
2    select 1,'a' from dual union all
 
3    select 2,'b' from dual union all
 
4    select 3,'c' from dual;
语句级别触发器before
行级别触发器before
行级别触发器after
行级别触发器before
行级别触发器after
行级别触发器before
行级别触发器after
语句级别触发器after

3 rows created.

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值