一 、触发器的概念:
触发器(trigger)是由关系型数据库(SQL Server)提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关联的特殊存储过程,它执行不是由程序调用,也不是手工启动,而是由事件触发,比如当对一个表进行操作(insert、update、delete)时就会触发它执行。触发器常用于加强数据的完整性约束和业务规划等。触发器可以从 DBA_TRIGGERS ,USER_TRIGGERS 数据字典中查到。SQL3的触发器是一个能由系统自动执行对数据库修改的语句。
二、触发器创建和使用:
CREATE TRIGGER `<databaseName>`.`<triggerName>` ----触发器名字、触发时间before/after
< [ BEFORE | AFTER ] > < [ INSERT | UPDATE | DELETE ] > ---触发事件
ON [dbo]<tableName> //dbo代表该表的所有者 ----针对那张表触发
FOR EACH ROW ---行级触发
BEGIN
--do something
END |
例子:触发器更新tb_emp之前触发,目的是不允许在周末修改表
-
触发器名:触发器对象的名称。由于触发器是数据库自动执行的,因此该名称只是一个名称,没有实质的用途
-
触发时间:指明触发器何时执行,该值可取
-
before:表示在数据库动作之前触发器执行
-
after:表示在数据库动作之后触发器执行
-
触发事件:指明哪些数据库动作会触发此触发器
-
insert:数据库插入会触发此触发器
-
update:数据库修改会触发此触发器
-
delete:数据库删除会触发此触发器
-
表 名:数据库触发器所在的表
-
for each row:对表的每一行触发器执行一次。如果没有这一选项,则只对整个表执行一次。
三、触发器的作用:
-
可在写入数据表前,强制检验或转换数据。
-
触发器发生错误时,异动的结果会被撤销。
-
部分数据库管理系统可以针对数据定义语言(DDL)使用触发器,称为DDL触发器。
-
可依照特定的情况,替换异动的指令 (INSTEAD OF)。
四、触发器分类:
- DML 触发器:当数据库中表中的数据发生变化时,包括insert,update,delete任意操作,如果我们对该表写了对应的DML触发器,那么该触发器自动执行。DML触发器的主要作用在于强制执行业 务规则,以及扩展Sql Server约束,默认值等。因为我们知道约束只能约束同一个表中的数据,而触发器中则可以执行任意Sql命令。
- DDL 触发器:它是Sql Server2005新增的触发器,主要用于审核与规范对数据库中表,触发器,视图等结构上的操作。比如在修改表,修改列,新增表,新增列等。它在数据库结构发生变化时执行,我们主要用它来记录数据库的修改过程,以及限制程序员对数据库的修改,比如不允许删除某些指定表等。
- 登录触发器:登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自 PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。
如果对大家有帮助的话,还望多回访,谢谢!