SQL Server 数据库触发器
目录
- SQL Server 数据库触发器
- 1.定义
- 2.作用
- 3.优缺点
- 4.语法
- 5.分类
1.定义
“触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。 触发器可以从 DBA_TRIGGERS ,USER_TRIGGERS 数据字典中查到。SQL3的触发器是一个能由系统自动执行对数据库修改的语句。触发器可以查询其他表,而且可以包含复杂的SQL语句。它们主要用于强制服从复杂的业务规则或要求。例如:您可以根据客户当前的帐户状态,控制是否允许插入新订单。触发器也可用于强制引用完整性,以便在多个表中添加、更新或删除行时,保留在这些表之间所定义的关系。然而,强制引用完整性的…”
2.作用
“可在写入数据表前,强制检验或转换数据。 触发器发生错误时,异动的结果会被撤销。 部分数据库管理系统可以针对数据定义语言(DDL)使用触发器,称为DDL触发器。 可依照特定的情况,替换异动的指令 (INSTEAD OF)。”
3.优缺点
使用触发器有如下优点:
- 自动执行。触发器在对表的数据作了任何修改(比如手工输入或者应用程序的操作)之后立即被激活。
- 级联更新。触发器可以通过数据库中的相关表进行层叠更改,这比直接把代码写在前台的做法更安全合理。
- 强化约束。触发器可以引用回其它表中的列,能够实现比CHECK约束更为复杂的约束。
- 跟踪变化。触发器可以阻止数据库中未经许可的指定更新和变答化。
- 强制业务逻辑。触发器可用于执行管理任务,并强制影响数据库的复杂业务规则。
使用触发器有如下缺点:
1.如果触发频率高,占用内存,降低数据访问速度
2.相对不灵活,一旦触发马上执行,不能排除特殊情况
3.一定程度上打乱代码结构,相关的代码都需要特别注释,否则造成阅读和维护上的困难
4.过度使用也会造成数据库的维护困难
4.语法
下面展示一些 内联代码片
。
ON:表示基于什么对象创建触发器。如果是AFTER触发器,则ON子句的对象必须是一个表,不能是视图。
WITH ENCRYPTION: 加密触发器代码
FOR|AFTER: 决定由什么类型的动作激发触发器,包括Delete、Insert、Update动作。FOR和AFTER表明了DML 触发器仅在触发 SQL 语句中指定的所有操作都已成功执行时才被激发。所有的引用级联操作和约束检查也必须在激发此触发器之前成功完成。
INSTEAD OF:这个功能可以用来对视图进行Delete、Insert、Update,动作的激发是在修改数据之前。
CREATE TRIGGER <trigger name>
ON [<schema name>.]<table or view name>
[WITH ENCRYPTION | EXECUTE AS <CALLER | SELF | <user> >]
{ FOR | AFTER | INSTEAD OF } { [ INSERT ] [ , ] [ UPDATE ] [ , ] [ DELETE ] }
[WITH APPEND]
[NOT FOR REPLICATION]
AS
< <sql statements> | EXTERNAL NAME <assembly method specifier> >
5.分类
DML触发器
当数据库中表中的数据发生变化时,包括insert,update,delete任意操作,如果我们对该表写了对应的DML触发器,那么该触发器自动执行。DML触发器的主要作用在于强制执行业 务规则,以及扩展Sql Server约束,默认值等。因为我们知道约束只能约束同一个表中的数据,而触发器中则可以执行任意Sql命令。
DDL触发器
它是Sql Server2005新增的触发器,主要用于审核与规范对数据库中表,触发器,视图等结构上的操作。比如在修改表,修改列,新增表,新增列等。它在数据库结构发生变化时执行,我们主要用它来记录数据库的修改过程,以及限制程序员对数据库的修改,比如不允许删除某些指定表等。
登录触发器
登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自 PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。