SQL Server触发器的使用

本文深入解析SQL触发器的概念,包括其定义、分类(DML、DDL、登录触发器)、优缺点及具体应用实例,帮助读者理解如何利用触发器增强数据完整性和业务规则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.定义

触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。
2.分类

常规类型的触发器有三种:DML触发器、DDL触发器和登录触发器

(1) DML(数据操作语言,Data Manipulation Language)触发器
   DML触发器是一些附加在特定表或视图上的操作代码,当数据库服务器中发生数据操作语言事件时执行这些操作。SqlServer中的DML触发器有三种:
   a) insert触发器:向表中插入数据时被触发;
   b) update触发器:修改表中数据时被触发;
   c) delete触发器:从表中删除数据时被触发。
   当遇到下列情形时,应考虑使用DML触发器:
   通过数据库中的相关表实现级联更改
   防止恶意或者错误的insert、update和delete操作,并强制执行check约束定义的限制更为复杂的其他限制。
   评估数据修改前后表的状态,并根据该差异才去措施。

(2) DDL(数据定义语言,Data Definition Language)触发器
 DDL触发器是当服务器或者数据库中发生数据定义语言(主要是以create,drop,alter开头的语句)事件时被激活使用,使用DDL触发器可以防止对数据架构进行的某些更改或记录数据中的更改或事件操作。

(3) 登录触发器
   登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自 PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。
3.优缺点

(1)优点

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

(2)缺点

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

4.实例

Insert 触发器:
在向目标表中插入数据后,会触发该表的Insert 触发器,系统自动在内存中创建inserted表; 下面的demo中对Age加了判断,如果不满足判断数据会进行回滚,插入的数据操作会失败。

Update 触发器:
在向目标表中更新数据后,会触发该表的Update 触发器,系统自动在内存中创建deleted表和inserted表,deleted表存放的是更新前的数据,inserted表存放的是更新的数据

Delete 触发器:
在向目标表中删除数据后,会触发该表的Delete 触发器,系统自动在内存中创建deleted表,deleted表存放的是删除的数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值