SQL SERVER 触发器简介及相关使用实例

触发器(trigger) 是sql server提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表相关的特殊的存储过程,它的执行不是由程序调动,也不需要手动启动,而是由事件来触发,比如当对一个表进行增删改时就会激活它的执行,触发器经常用于加强数据完整性约束和业务规则等。
Sql Server包括三种常规类型的触发器:DML触发器,DLL触发器和登录触发器。

  1. DML(数据操纵语言Data Manipulation Language)触发器:DML触发器是一些附加在特定表上或视图上的操作代码;sql server 中的DML触发器有三种:insert触发器:向表中插入数据时被触发; update触发器:修改表中数据时被触发;delete触发器:从表中删除数据时被触发。防止恶意或者错误的insert、update和delete操作,并强制执行check约束定义的限制更为复杂的其他限制。
  2. DLL(数据定义语言Data Definition Language)触发器:DDL触发器是当服务器或者数据库中发生数据定义语言(主要是以create,drop,alter开头的语句)事件时被激活使用,使用DDL触发器可以防止对数据架构进行的某些更改或记录数据中的更改或事件操作。
  3. 登录触发器:登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自 PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。

DML触发器:
    DML触发器执行时,系统内存会自动生成deleted和inserted表,执行结束会自动消失。Update触发器,使用到deleted表和inserted表;
在这里插入图片描述
相关代码:

--Insert 触发器
Create TRIGGER [dbo].[Trigger_Insert]
   ON  [dbo].[Person]
   AFTER INSERT
AS 
BEGIN
	Declare @age int;
	Select @age=Age  From inserted--从inserted表中查询刚插入的数据年龄项

	--如果年龄小于150正常插入,否则数据回滚
	IF(@age<150)
		Begin
			Insert into PersonLog(PersonID, Name, Age, AddDate)
			Select ID, Name, Age, AddDate From inserted
		End
	ELSE
		Begin
		    print('年龄应小于150')
			rollback transaction     --数据回滚
		END
    
END

触发器优点:

  1. 强化约束:强制复杂业务的规则和要求,能实现比check语句更为复杂的约束。
  2. .跟踪变化:触发器可以侦测数据库内的操作,从而禁止数据库中未经许可的更新和变化。
  3. 级联运行:侦测数据库内的操作时,可自动地级联影响整个数据库的各项内容。
  4. 嵌套调用:触发器可以调用一个或多个存储过程。触发器最多可以嵌套32层。

触发器缺点:

  1. 可移植性差。
  2. 用服务器资源,给服务器造成压力。
  3. 执行速度主要取决于数据库服务器的性能与触发器代码的复杂程度。
  4. 嵌套调用一旦出现问题,排错困难,而且数据容易造成不一致,后期维护不方便。

相关使用建议:

  • 尽量避免在触发器中执行耗时操作,因为触发器会与SQL语句认为在同一事务中,事务不结束,就无法释放锁。
  • 避免在触发器中做复杂操作,影响触发器性能的因素比较多(Eg:产品版本,所使用的架构等),要想编写高效的触发器考虑因素比较多,编写高性能触发器还是很难的
发布了21 篇原创文章 · 获赞 3 · 访问量 346

猜你喜欢

转载自blog.csdn.net/MrLsss/article/details/104084761