首页 > 数据库 >SQL server 触发器

SQL server 触发器

时间:2023-03-09 17:36:20浏览次数:34  
标签:触发 触发器 SQL server 表中 数据

触发器

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

触发器的分类:

  • DML触发器
  • DDL触发器
  • 登录触发器

DML触发器

DML触发器是一些附加在特定表和视图上的操作代码,当数据库服务器中发生数据操作语言事件时执行这些操作。

SQL server中的DML触发器有三种:

  1. insert触发器:想表中插入数据时被触发。

insert触发器:

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

  1. delete触发器:从表中删除数据时被触发。

delete触发器:

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

  1. update触发器:修改表中数据时被触发。

update触发器:

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

当遇到下列情形是,应考虑使用DML触发器:

  • 通过数据库中的相关表实现级联更改
  • 防止恶意或者错误的insert、update和delete操作,并强制执行check约束定义的限制更为复杂的其他限制。
  • 评估数据修改前后表的状态,并根据该差异采取措施。

DDL触发器(数据库定义语言,Data Definition Language)

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

登录触发器

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

标签:触发,触发器,SQL,server,表中,数据
From: https://www.cnblogs.com/counter/p/17199283.html

相关文章