[oracle] oracle触发器中的after和before有什么区别 , 语句级触发和行级触发有什么区别
2010-07-16 00:57
603 查看
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.
一个是在记录操作之前触发,一个是在记录操作之后触发。
比如表之间定义的有外键,在删除主键时,必须要先删除外键表,这时就有先后之分。
语句级触发和行级触发区别:
语句级别触发器只触发一次、行级触发器是作用了多少行触发多少次。
如果定义为语句级,则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.
相关文章推荐
- [oracle] oracle触发器中的after和before有什么区别 , 语句级触发和行级触发有什么区别
- 触发器分为事前触发和事后触发,这两种触发有何区别?语句级触发和行级触发有何区别
- jquery的append/prepend和after/before有什么区别呢?
- jQuery的append/prepend和after/before有什么区别?
- CSS3 ::before 和 :after中双冒号和单冒号 有什么区别?
- oracle 触发器before和after数据区别
- 常用SQL查询语句 Oracle中Union,Union All,Intersect,Minus的有什么区别
- Oracle数据库中before触发与after触发的区别
- Oracle Trigger :Before,after,each row and table level triggers ORA-04082 ORA-04084
- oracle备份恢复之recover database的四条语句区别
- Oracle 删除数据两种语句: DELETE 和 TRUNCATE 的区别
- oracle sql 语句中where条件中 1=1 是什么意思
- oracle10g- oracle 触发器 行级触发器 语句级触发器 替换触发器
- spring AOP @Around @Before @After 区别
- C#中??和?分别是什么意思? 在ASP.NET开发中一些单词的标准缩写 C#SESSION丢失问题的解决办法 在C#中INTERFACE与ABSTRACT CLASS的区别 SQL命令语句小技巧 JQUERY判断CHECKBOX是否选中三种方法 JS中!=、==、!==、===的用法和区别 在对象比较中,对象相等和对象一致分别指的是什么?
- 条件语句中 字段= 值 和 值=字段 有什么区别
- 第一次安装Oracle10后不能登陆问题的解决以及nolog的区别以及建库语句
- oracle.jdbc.driver.OracleDriver和oracle.jdbc.OracleDriver这两个驱动有什么区别?
- mysql之触发器before和after的区别(2)
- mysql 触发器after与before的区别