`

触发器(trigger)学习笔记

阅读更多

触发器(trigger)是个特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。 触发器可以从 DBA_TRIGGERS ,USER_TRIGGERS 数据字典中查到。

创建触发器的SQL语法

  DELIMITER |

  CREATE TRIGGER `<databaseName>`.`<triggerName>`

  < [ BEFORE | AFTER ] > < [ INSERT | UPDATE | DELETE ] >

  ON <tableName>

  FOR EACH ROW

  BEGIN

  --do something

  END

触发器的优点

  触发器可通过数据库中的相关表实现级联更改;不过,通过级联引用完整性约束可以更有效地执行这些更改。触发器可以强制比用 CHECK 约束定义的约束更为复杂的约束。与 CHECK 约束不同,触发器可以引用其它表中的列。例如,触发器可以使用另一个表中的 SELECT 比较插入或更新的数据,以及执行其它操作,如修改数据或显示用户定义错误信息。触发器也可以评估数据修改前后的表状态,并根据其差异采取对策。一个表中的多个同类触发器(INSERT、UPDATE 或 DELETE)允许采取多个不同的对策以响应同一个修改语句。

慎用触发器

  触发器功能强大,轻松可靠地实现许多复杂的功能,为什么又要慎用呢。触发器本身没有过错,但由于我们的滥用会造成数据库及应用程序的维护困难。在数据库操作中,我们可以通过关系、触发器、存储过程、应用程序等来实现数据操作…… 同时规则、约束、缺省值也是保证数据完整性的重要保障。如果我们对触发器过分的依赖,势必影响数据库的结构,同时增加了维护的复杂程序.

触发器实例

trigger
create or replace trigger "TEAM_MEMBER"
before insert or update on TEAM_MEMBER
for each row
declare
BEGIN
if inserting then

doSomeThing();
end if;
if updating then
doSomeThing();

end if;
end;

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics