如何分析SQL Server数据库触发器概念、原理及案例

68次阅读
没有评论

共计 4115 个字符,预计需要花费 11 分钟才能阅读完成。

如何分析 SQL Server 数据库触发器概念、原理及案例,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面丸趣 TV 小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

概述

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

一、触发器的优点

1. 触发器是自动的。当对表中的数据做了任何修改之后立即被激活。

2. 触发器可以通过数据库中的相关表进行层叠修改。

3. 触发器可以强制限制。这些限制比用 CHECK 约束所定义的更复杂。与 CHECK 约束不同的是,触发器可以引用其他表中的列。

二、触发器的分类

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

1.DML(数据操作语言,Data Manipulation Language)触发器

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

insert 触发器: 向表中插入数据时被触发;

delete 触发器:从表中删除数据时被触发;

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

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

通过数据库中的相关表实现级联更改

防止恶意或者错误的 insert、update 和 delete 操作,并强制执行 check 约束定义的限制更为复杂的其他限制。

评估数据修改前后表的状态,并根据该差异才去措施。

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

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

3. 登录触发器

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

三、触发器的工作原理

[DELETE, INSERT, UPDATE]对应为当执行删除、插入、更新三种动作时被触发

执行 insert 时,获取插入后的数据,可用 select*from inserted 读取

执行 delete 时,获取删除前的数据,可用 select*from deleted 读取

执行 update 时,获取更新前的数据,可用 select*from deleted 读取,获取更新后数据,可用 select*from  inserted 读取

四、创建触发器

1、创建触发器的语法:

CREATE TRIGGER trigger_name ON table_name [WITH ENCRYPTION] FOR | AFTER | INSTEAD OF [DELETE, INSERT, UPDATE] AS T-SQL 语句  GO --with encryption  表示加密触发器定义的 sql 文本  --delete,insert,update 指定触发器的类型

2、创建 insert 触发器

-- 创建 insert 触发器  create trigger trig_insert on student after insert as begin if object_id(N student_sum ,N U) is null-- 判断 student_sum 表是否存在  create table student_sum(stuCount int default(0));-- 创建存储学生人数的 student_sum 表  declare @stuNumber int; select @stuNumber = count(*)from student; if not exists (select * from student_sum)-- 判断表中是否有记录  insert into student_sum values(0); update student_sum set stuCount =@stuNumber; -- 把更新后总的学生数插入到 student_sum 表中  end -- 测试触发器 trig_insert-- 功能是向 student 插入数据的同时级联插入到 student_sum 表中,更新 stuCount -- 因为是后触发器,所以先插入数据后,才触发触发器 trig_insert; insert into student(stu_name,stu_gender,stu_age)values(吕布 , 男 ,30); select stuCount  学生总人数  from student_sum; insert into student(stu_name,stu_gender,stu_age)values(貂蝉 , 女 ,30); select stuCount  学生总人数  from student_sum; insert into student(stu_name,stu_gender,stu_age)values(曹阿瞒 , 男 ,40); select stuCount  学生总人数  from student_sum;

3、创建 delete 触发器

用户执行 delete 操作,就会激活 delete 触发器,从而控制用户能够从数据库中删除数据记录,触发 delete 触发器后,用户删除的记录会被添加到 deleted 表中,原来表的相应记录被删除,所以在 deleted 表中查看删除的记录。

-- 创建 delete 触发器  create trigger trig_delete on student after delete as begin select stu_id as  已删除的学生编号,stu_name stu_gender,stu_age from deleted end; -- 执行一一条 delete 语句触发 trig_delete 触发器  delete from student where stu_id=1;

4、创建 UPDATE 触发器

update 触发器是当用户在指定表上执行 update 语句时被调用被调用,这种类型的触发器用来约束用户对数据的修改。update 触发器可以执行两种操作:更新前的记录存储在 deleted 表中,更新后的记录存储在 inserted 表中。

-- 创建 update 触发器  create trigger trig_update on student after update as begin declare @stuCount int; select @stuCount=count(*) from student; update student_sum set stuCount =@stuCount; select stu_id as  更新前学生编号,stu_name as  更新前学生姓名  from deleted select stu_id as  更新后学生编号,stu_name as  更新后学生姓名  from inserted end -- 创建完成,执行一条 update 语句触发 trig_update 触发器  update student set stu_name= 张飞  where stu_id=2;

五、管理触发器

1. 查看触发器

(1). 查看数据库中所有的触发器

-- 查看数据库中所有的触发器  use  数据库名  go select * from sysobjects where xtype= TR

sysobjects 保存着数据库的对象,其中 xtype 为 TR 的记录即为触发器对象。在 name 一列,我们可以看到触发器名称。

(2).sp_helptext 查看触发器内容

use  数据库名  go exec sp_helptext  触发器名称

将会以表的样式显示触发器内容。

除了触发器外,sp_helptext 还可以显示 规则、默认值、未加密的存储过程、用户定义函数、视图的文本。

(3).sp_helptrigger 用于查看触发器的属性

sp_helptrigger 有两个参数:第一个参数为表名; 第二个为触发器类型,为 char(6) 类型,可以是  INSERT、UPDATE、DELETE,如果省略则显示指定表中所有类型触发器的属性。

-- 查看数据库中所有的触发器  use  数据库名  go select * from sysobjects where xtype= TR

use 数据库名 goexec sp_helptrigger tableName

2. 禁用启用触发器

禁用:alter table 表名 disable trigger 触发器名称

启用:alter table 表名 enable trigger 触发器名称

如果有多个触发器,则各个触发器名称之间用英文逗号隔开。

如果把“触发器名称”换成“ALL”,则表示禁用或启用该表的全部触发器。

3. 修改触发器

-- 修改触发器语法  ALTER TRIGGER trigger_name ON table_name [ WITH ENCRYPTION ] FOR {[DELETE][,][INSERT][,][UPDATE]} AS sql_statement;

4. 删除触发器

 -- 语法格式: DROP TRIGGER { trigger } [ ,...n ]  参数: trigger:  要删除的触发器名称  n: 表示可以删除多个触发器的占位符

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注丸趣 TV 行业资讯频道,感谢您对丸趣 TV 的支持。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-18发表,共计4115字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)