触发器

来源:互联网 发布:it所有格 编辑:程序博客网 时间:2024/04/28 12:50
触发器(trigger)是个特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由个事件来触发,比如当对一个表进行操作( insert,delete, update)时SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。 触发器经常用于加强数据的完整性约束和业务规则等。 触发器可以从 DBA_TRIGGERS ,USER_TRIGGERS 数据字典中查到。
触发器的主要作用就是其能够实现由主键和外键所不能保证的复杂的参照完整性和数据的一致性。除此之外,触发器还有其它许多不同的功能: 
(1) 强化约束(Enforce restriction) 
触发器能够实现比CHECK 语句更为复杂的约束。 
(2) 跟踪变化Auditing changes 
触发器可以侦测数据库内的操作,从而不允许数据库中未经许可的指定更新和变化。 
(3) 级联运行(Cascaded operation)。 
触发器可以侦测数据库内的操作,并自动地级联影响整个数据库的各项内容。例如,某个表上的触发器中包含有对另外一个表的数据操作(如删除,更新,插入)而该操作又导致该表上触发器被触发。 
(4) 存储过程的调用(Stored procedure invocation)。 
为了响应数据库更新,触发器可以调用一个或多个存储过程,甚至可以通过外部过程的调用而在DBMS( 数据库管理系统)本身之外进行操作。 
由此可见,触发器可以解决高级形式的业务规则或复杂行为限制以及实现定制记录等一些方面的问题。例如,触发器能够找出某一表在数据修改前后状态发生的差异,并根据这种差异执行一定的处理。此外一个表的同一类型(INSERT、 UPDATE、 DELETE)的多个触发器能够对同一种数据操作采取多种不同的处理。 
总体而言,触发器性能通常比较低。当运行触发器时,系统处理的大部分时间花费在参照其它表的这一处理上,因为这些表既不在内存中也不在数据库设备上,而删除表和插入表总是位于内存中。可见触发器所参照的其它表的位置决定了操作要花费的时间长短。


SQL Server触发器的种类 
SQL Server 2000 支持两种类型的触发器:AFTER 触发器和INSTEAD OF 触发器。其中AFTER 触发器即为SQL Server 2000 版本以前所介绍的触发器。该类型触发器要求只有执行某一操作(INSERT UPDATE DELETE) 之后,触发器才被触发,且只能在表上定义。可以为针对表的同一操作定义多个触发器。对于AFTER 触发器,可以定义哪一个触发器被最先触发,哪一个被最后触发,通常使用系统过程sp_settriggerorder 来完成此任务。 
INSTEAD OF 触发器表示并不执行其所定义的操作(INSERT、 UPDATE、 DELETE),而仅是执行触发器本身。既可在表上定义INSTEAD OF 触发器,也可以在视图上定义INSTEAD OF 触发器,但对同一操作只能定义一个INSTEAD OF 触发器。


ORACLE触发器的种类

语句级触发器,以及行级触发器,前者可以在语句执行前或执行后被触发。后者在每个触发语句影响的行触发一次。还有before和after触发的命令。在insert,update,和delete之前或之后执行,引用新旧值进行处理。如果需通过触发器设定插入行中的某列值,则为了访问“新(new)”值,需使用一个触发器before insert,使用after insert则不行。Instead of 触发器命令,使用它告诉oracle应执行什么操作。


触发器

其是一种特殊的存储过程。一般的存储过程是通过存储过程名直接调用,而触发器主要是通过事件(增、删、改)进行触发而被执行的。其在表中数据发生变化时自动强制执行。

  常见的触发器有两种:after(for)、instead of,用于insert、update、delete事件。

  after(for) 表示执行代码后,执行触发器

  instead of 表示执行代码前,用已经写好的触发器代替你的操作

触发器语法:

  create trigger 触发器的名字 on 操作表

  for|after instead of

  update|insert|delete

  as

  SQL语句

触发器实现原理图

触发器示例

Example1

--禁止用户插入数据(实际上是先插入,然后立刻将其删除!)

  create trigger tr_insert on bank

  for --for表示执行之后的操作

  insert --即先执行了插入操作,同时在临时表中保存了插入记录

  as

  --执行完插入之后,在新生成的表中将刚刚插入的那条记录删除,

   --而此时得到的刚刚插入的记录的id是通过临时表 inserted得到的

  delete * from bank where cid=(select cid from inserted)

  生成上面的触发器后,当用户再输入insert语句后就见不到效果了!

  如:insert into bank values('0004',10000),是插入不进数据库的。

Example2

--删除谁就让谁的账户加上10元

  create trigger tr_dalete on bank

  instead of

  delete

  as

  update bank balance=balance+10 where cid=(select cid from deleted)

  生成这个触发器之后,当用户输入delete语句后,对应的那个id不但没有被删除掉,而且他的账户增加了10元

  如:delete from bank where cid='0002',执行完这句话后,编号为0002的账户会增加10元




参考:

http://blog.csdn.net/zdwzzu2006/article/details/5946922

http://www.cnblogs.com/Alpha-Fly/archive/2012/04/09/2438419.html

0 0
原创粉丝点击