SQL Server 触发器
触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。
SQL Server包括三种常规类型的触发器:DML触发器、DDL触发器和登录触发器。
- DML(数据操作语言,Data Manipulation Language)触发器
DML触发器是一些附加在特定表或视图上的操作代码,当数据库服务器中发生数据操作语言事件时执行这些操作。SqlServer中的DML触发器有三种:
insert触发器:向表中插入数据时被触发;
update触发器:修改表中数据时被触发;
delete触发器:从表中删除数据时被触发。
当遇到下列情形时,应考虑使用DML触发器:
通过数据库中的相关表实现级联更改
防止恶意或者错误的insert、update和delete操作,并强制执行check约束定义的限制更为复杂的其他限制。
评估数据修改前后表的状态,并根据该差异才去措施。
DDL(数据定义语言,Data Definition Language)触发器
DDL触发器是当服务器或者数据库中发生数据定义语言(主要是以create,drop,alter开头的语句)事件时被激活使用,使用DDL触发器可以防止对数据架构进行的某些更改或记录数据中的更改或事件操作。登录触发器
登录触发器将为响应 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
BEGINSET NOCOUNT ON;Declare @age int;Select @age=Age From inserted--如果年龄小于150正常插入,否则数据回滚IF(@age<150)BeginInsert into PersonLog(PersonID, Name, Age, AddDate)Select ID, Name, Age, AddDate From insertedEndELSEBeginprint('年龄应小于150')rollback transaction --数据回滚ENDEND
Update 触发器:
在向目标表中更新数据后,会触发该表的Update 触发器,系统自动在内存中创建deleted表和inserted表,deleted表存放的是更新前的数据,inserted表存放的是更新的数据。
--Update 触发器
Create TRIGGER [dbo].[Trigger_Update]ON [dbo].[Person]AFTER UPDATE
AS BEGIN SET NOCOUNT ON;--这里是先删除后插入,存在一张临时表deletedInsert Into PersonLog(PersonID, Name, Age, AddDate, UpdateDate)Select ID, Name, Age, AddDate, UpdateDate From insertedEND
Delete 触发器:
在向目标表中删除数据后,会触发该表的Delete 触发器,系统自动在内存中创建deleted表,deleted表存放的是删除的数据。
--Delete 触发器
Create TRIGGER [dbo].[Trigger_Delete]ON [dbo].[Person]AFTER DELETE
AS
BEGINSET NOCOUNT ON;Insert Into PersonLog(PersonID, Name, Age, AddDate, UpdateDate, DeleteDate)Select ID, Name, Age, AddDate, UpdateDate, GETDATE() From deletedEND
触发器优点:
1.强化约束:强制复杂业务的规则和要求,能实现比check语句更为复杂的约束。
2.跟踪变化:触发器可以侦测数据库内的操作,从而禁止数据库中未经许可的更新和变化。
3.级联运行:侦测数据库内的操作时,可自动地级联影响整个数据库的各项内容。
4.嵌套调用:触发器可以调用一个或多个存储过程。触发器最多可以嵌套32层。
触发器缺点:
1. 可移植性差。
2.占用服务器资源,给服务器造成压力。
3.执行速度主要取决于数据库服务器的性能与触发器代码的复杂程度。
4.嵌套调用一旦出现问题,排错困难,而且数据容易造成不一致,后期维护不方便。
触发器使用建议:
1.尽量避免在触发器中执行耗时操作,因为触发器会与SQL语句认为在同一事务中,事务不结束,就无法释放锁。
2.避免在触发器中做复杂操作,影响触发器性能的因素比较多(Eg:产品版本,所使用的架构等),要想编写高效的触发器考虑因素比较多,编写高性能触发器还是很难的。
3.触发器编写时注意多行触发时的处理。(一般不建议使用游标)
SQL Server 触发器相关推荐
- SQL Server 触发器学习总结
SQL菜鸟入门级教程之触发器 触发器简介: 触发器(trigger)是种特殊的存储过程,它的执行不是由程序调用,也不需要手动操作,它是由事件来触发,事件大家应该非常熟悉吧,比如按钮的Click事件 ...
- SQL server触发器中 update insert delete 分别给写个例子被。
SQL server触发器中 update insert delete 分别给写个例子以及解释下例子的作用和意思被, 万分感谢!!!! 主要想知道下各个语句的书写规范. INSERT: 表1 (ID, ...
- 了解SQL Server触发器及触发器中的事务
引述 首先,写这篇文章的目的是望能把我对触发器的理解,分享出来与大家一起学习.如果你对触发器和事务的概念有些了解,这篇文章对你来说会是很简单,或能让你更进一步的了解触发器里面的一些故事,以及触发器中事 ...
- 【转】了解SQL Server触发器及触发器中的事务
引述 首先, 说下我写篇文章的目的,我希望能把我对触发器的理解,分享出来与你一起学习.如果你有对触发器和事务的概念,有些了解,这篇文章,对你来说会是很简单,或能让你更进一步的了解触发器里面的一些故事, ...
- SQL Server触发器创建、删除、修改、查看
http://blog.csdn.net/tianwailaibin/article/details/8111766 本教程为大家介绍SQL Server触发器创建.删除.修改.查看方法. 一.触发器 ...
- mysql 触发器 sql server_喜忧参半的SQL Server触发器
SQL Server触发器在非常有争议的主题.它们能以较低的成本提供便利,但经常被开发人员.DBA误用,导致性能瓶颈或维护性挑战. 本文简要回顾了触发器,并深入讨论了如何有效地使用触发器,以及何时触发 ...
- 15、SQL Server 触发器
SQL Server 触发器 触发器是一种特殊的存储过程,只有当试图用数据操作语言DML来修改数据时才会触发,DML包含对视图和表的增.删.改. 触发器分为DML触发器和DDL触发器,其中DML触发器 ...
- sql 服务器实例怎样显示,SQL Server 触发器实例详解
Microsoft SQL Server™ 2000 提供了两种主要机制来强制业务规则和数据完整性:约束和触发器.触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程.触发器主要是通过事件 ...
- SQL server 触发器 instead of
数据库SQL SERVER 触发器操作(部分) 使用instead of insert 在 课程表COURSE 中设置触发器,使老师张青的教授课程不超过3门 CREATE TRIGGER INSER ...
- sql server 触发器实时同步数据库表数据
sql server 触发器实时同步数据库表数据 创建两个相同结构的数据库表 CREATE TABLE [dbo].[Table_1]([id] [varchar](50) NOT NULL,[nam ...
最新文章
- android 正则表达式3,含有至少3个字符类型的android正则表达式
- SpringMVC框架 学习DAY_03:@RequestMapping注解/拦截器与过滤器
- 推荐一款非常不错的子网计算器
- iphone开发如何测试?
- Vue.js 组件注册
- checkInterruptWhileWaiting
- could not create the java virtual machine启动eclipse报错
- c 语言栈,C语言栈
- js调用微信扫一扫demo_JS 调用微信扫一扫功能
- 并发测试工具_性能测试工具基本工作原理及基本操作流程
- Java 算法 入学考试
- 如何关闭OSX 10.11 SIP (System Integrity Protection)
- Please review your Gradle project setup in the android/ folde
- 不同角色给rules重新赋值校验规则
- DailyWallpaper v1.02 released
- 1.2 矩阵与线性方程组-向量空间、内积空间与线性映射
- HTML5电子书阅读器
- 三菱Q系列PLC大型程序Q01U伺服12轴
- H5唤起 uniapp 版的app 端
- Notepad++的64位HexEditor免费下载