SQL Server 触发器[通俗易懂]

SQL Server 触发器[通俗易懂]SQLServer触发器

大家好,又见面了,我是你们的朋友全栈君。

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

SQL Server包括三种常规类型的触发器:DML触发器、DDL触发器和登录触发器。

  1. DML(数据操作语言,Data Manipulation Language)触发器
       DML触发器是一些附加在特定表或视图上的操作代码,当数据库服务器中发生数据操作语言事件时执行这些操作。SqlServer中的DML触发器有三种:
       insert触发器:向表中插入数据时被触发;
       update触发器:修改表中数据时被触发;
        delete触发器:从表中删除数据时被触发。

       当遇到下列情形时,应考虑使用DML触发器:
        通过数据库中的相关表实现级联更改
        防止恶意或者错误的insert、update和delete操作,并强制执行check约束定义的限制更为复杂的其他限制。
        评估数据修改前后表的状态,并根据该差异才去措施。

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

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

DML触发器
 DML触发器执行时,系统内存会自动生成deleted表或inserted表,执行结束会自动消失。
   Insert触发器,使用到inserted表;
   Update触发器,使用到deleted表和inserted表;
   Delete触发器,使用到deleted表。
下面引用一张图,简单明了展示了DML触发器:
在这里插入图片描述
DML触发器Demo
   表结构如下:
在这里插入图片描述

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

--Insert 触发器
Create TRIGGER [dbo].[Trigger_Insert]
   ON  [dbo].[Person]
   AFTER INSERT
AS 
BEGIN
	
	SET NOCOUNT ON;

	Declare @age int;
	Select @age=Age  From 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

在这里插入图片描述
Update 触发器:
在向目标表中更新数据后,会触发该表的Update 触发器,系统自动在内存中创建deleted表和inserted表,deleted表存放的是更新前的数据,inserted表存放的是更新的数据。

--Update 触发器
Create TRIGGER [dbo].[Trigger_Update]
   ON  [dbo].[Person]
   AFTER UPDATE
AS 

BEGIN	
	SET NOCOUNT ON;

	--这里是先删除后插入,存在一张临时表deleted
    Insert Into PersonLog(PersonID, Name, Age, AddDate, UpdateDate)
	Select ID, Name, Age, AddDate, UpdateDate From inserted

END

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

--Delete 触发器
Create TRIGGER [dbo].[Trigger_Delete]
   ON  [dbo].[Person]
   AFTER DELETE
AS 
BEGIN
	SET NOCOUNT ON;

    Insert Into PersonLog(PersonID, Name, Age, AddDate, UpdateDate, DeleteDate)
	Select ID, Name, Age, AddDate, UpdateDate, GETDATE() From deleted

END

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

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

触发器使用建议:
        1.尽量避免在触发器中执行耗时操作,因为触发器会与SQL语句认为在同一事务中,事务不结束,就无法释放锁。
        2.避免在触发器中做复杂操作,影响触发器性能的因素比较多(Eg:产品版本,所使用的架构等),要想编写高效的触发器考虑因素比较多,编写高性能触发器还是很难的。
        3.触发器编写时注意多行触发时的处理。(一般不建议使用游标)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/151673.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 85℃蛋糕店_蛋糕吧

    85℃蛋糕店_蛋糕吧题目描述今天是路路的生日,生日蛋糕自然是少不了。路路的朋友们一起去蛋糕店来买蛋糕,可是等一行人到了蛋糕店之后,发现那里是人山人海啊-_-。这下可把店家给急坏了,因为人数过多,需求过大,所以人们要等好长时间才能拿到自己的蛋糕。老板为了最大限度的使每位客人尽快拿到蛋糕,因此他需要安排一个制作顺序,使每位客人的平均等待时间最少(如果制作时间相同的,先来的先做)。这使他发愁了,于是他请你来帮忙安排一个…

    2025年7月5日
    8
  • 创建位图索引

    创建位图索引创建位图索引位图索引 1 位图索引与 B 树索引不同 位图索引不存储 rowid 值 数据实际物理地址 也不存储键值 2 在特殊的列上创建位图索引 3 特殊的列是指该列的基数很低的列 基数 列值的数量比列的行数来的小 举例 性别列的取值只有 2 个 男女 但是性别列的行数远远大于该列的取值 4 基数很低的列不适合 B 树索引 适合位图索引 oracle 建议 当一个列的所有取值数量与该列的行数比小于 1

    2025年10月9日
    3
  • 菜鸟的数学建模之路(四):BP神经网络

    个人理解BP神经网络属于人工智能范畴,在我看来它更多的是一个用于预测的工具,尽管它的用处还不仅于此。在数学建模上,很多时候,题目提供了很多历史数据,我经常用这些历史数据,用BP神经网络训练它,利用训练好的BP神经网络,来预测接下来的未知的值。BP神经网络关于该神经网络的繁多的理论这里就不去深究了,百度一查一大把,一堆的理论反正我是看不下去的,所以这里只是讲如何把BP神经网络当成一个工具来用,…

    2022年4月9日
    61
  • 哥德尔定理证明中的标号(11)-(16)——哥德尔读后之26

    哥德尔定理证明中的标号(11)-(16)——哥德尔读后之26哥德尔定理证明中的标号 11 16 哥德尔读后之 26 读哥德尔又遇到理解的困难 这个阅读受困的时段 正是因老桂大寿建立的几个科哲微信群讨论东方思维西方思维 还有辩证逻辑非辩证逻辑等等观念的时段 对科哲所知有限 但对思维与逻辑应该还有点感觉 东方和西方思维的分划 我感觉是一个伪分划 思维如果有地缘之分 那其实不是因地缘在划分思维 而是因地缘在划分语言 东西方人因地缘之故 有各种不同的自然语言 而显得思维似乎是各不相同 逻辑分为辩证和非辩证也是一个奇怪的分划 其实是一个非学术性 带有点实用意义的分划 这

    2026年1月20日
    1
  • python django做网页_响应式网页怎么做啊

    python django做网页_响应式网页怎么做啊这篇文字适合刚学习Django的同学,如果比较熟的就不用看了。以下都是讲在windows上的部署情况;准备:1、python3.62、pycharm profession(专业版)3、安装Django模块以上的安装就不讲了,比较简单,网上也有很多教程。都去官网下载安装即可。 前言:学习django框架其实就是学习它的文件目录,目录下有一些必须的模块和包,当然你也…

    2022年10月13日
    4
  • 【数据库管理】ORA-01017错误及部分的常见典型案例

    【数据库管理】ORA-01017错误及部分的常见典型案例本文将介绍对于数据库登录时ORA-01017错误问题的基本对应思路和一些典型的案例。

    2022年5月31日
    46

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号