ToB企服应用市场:ToB评测及商务社交产业平台

标题: SQL Server 触发器 [打印本页]

作者: 数据人与超自然意识    时间: 2022-6-25 04:23
标题: SQL Server 触发器
触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。
SQL Server包括三种常规类型的触发器:DML触发器、DDL触发器和登录触发器。
       当遇到下列情形时,应考虑使用DML触发器:
        通过数据库中的相关表实现级联更改
        防止恶意或者错误的insert、update和delete操作,并强制执行check约束定义的限制更为复杂的其他限制。
        评估数据修改前后表的状态,并根据该差异才去措施。
DML触发器
 DML触发器执行时,系统内存会自动生成deleted表或inserted表,执行结束会自动消失。
   Insert触发器,使用到inserted表;
   Update触发器,使用到deleted表和inserted表;
   Delete触发器,使用到deleted表。
下面引用一张图,简单明了展示了DML触发器:

DML触发器Demo
   表结构如下:

Insert 触发器:
在向目标表中插入数据后,会触发该表的Insert 触发器,系统自动在内存中创建inserted表; 下面的demo中对Age加了判断,如果不满足判断数据会进行回滚,插入的数据操作会失败。
[code]--Insert 触发器Create TRIGGER [dbo].[Trigger_Insert]   ON  [dbo].[Person]   AFTER INSERTAS BEGIN                SET NOCOUNT ON;        Declare @age int;        Select @age=Age  From inserted        --如果年龄小于150正常插入,否则数据回滚        IF(@age




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4