仿做唯品会网站,链接在线缩短,长沙内容营销公司,wordpress knowall主题概念#xff1a; 触发器#xff08;trigger#xff09;是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法#xff0c;它是与表事件相关的特殊的存储过程#xff0c;它的执行不是由程序调用#xff0c;也不是手工启动#xff0c;而是由事件来触发#x…概念 触发器trigger是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法它是与表事件相关的特殊的存储过程它的执行不是由程序调用也不是手工启动而是由事件来触发当对一个表进行操作 insertdelete update时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。 触发器可以从 DBA_TRIGGERS USER_TRIGGERS 数据字典中查到。
触发器和存储过程的区别: 触发器与存储过程的区别是运行方式的不同触发器不能执行EXECUTE语句调用而是在用户执行Transact-SQL语句时自动触发执行而存储过程需要用户应用程序或者触发器来显示地调用并执行。 一:触发器的优点 1.触发器是自动的。当对表中的数据做了任何修改之后立即被激活。 2.触发器可以通过数据库中的相关表进行层叠修改。 3.触发器可以强制限制。这些限制比用CHECK约束所定义的更复杂。与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 错误日志。如果身份验证失败将不激发登录触发器。 四触发器的工作原理
触发器触发时
系统自动在内存中创建deleted表或inserted表只读不允许修改触发器执行完成后自动删除。
inserted表
临时保存了插入或更新后的记录行可以从inserted表中检查插入的数据是否满足业务需求如果不满足则向用户发送报告错误消息并回滚插入操作。
deleted表
临时保存了删除或更新前的记录行可以从deleted表中检查被删除的数据是否满足业务需求如果不满足则向用户报告错误消息并回滚插入操作。
inserted表和deleted表对照
修改操作记录inserted表deleted表增加(insert)记录存放新增的记录............删除(deleted)记录..............存放被删除的记录修改(update)记录存放更新后的记录存放更新前的记录 回到顶部
五:创建触发器 创建触发器的语法 CREATE TRIGGER trigger_nameON table_name[WITH ENCRYPTION]FOR | AFTER | INSTEAD OF [DELETE, INSERT, UPDATE]AS T-SQL语句
GO
--with encryption 表示加密触发器定义的sql文本
--delete,insert,update指定触发器的类型 准备测试数据:
--创建学生表
create table student(stu_id int identity(1,1) primary key,stu_name varchar(10),stu_gender char(2),stu_age int
)
1.创建insert触发器
--创建insert触发器
create trigger trig_insert
on student
after insert
as
beginif object_id(Nstudent_sum,NU) 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;
执行上面的语句后结果如下图所示 既然定义了学生总数表student_sum表是向student表中插入数据后才计算学生总数的所以学生总数表应该禁止用户向其中插入数据
--创建insert_forbidden,禁止用户向student_sum表中插入数据
create trigger insert_forbidden
on student_sum
after insert
as
beginRAISERROR(禁止直接向该表中插入记录操作被禁止,1,1)--raiserror 是用于抛出一个错误
rollback transaction
end
--触发触发器insert_forbidden
insert student_sum (stuCount) values(5); 结果如下 2.创建delete触发器 用户执行delete操作就会激活delete触发器从而控制用户能够从数据库中删除数据记录触发delete触发器后用户删除的记录会被添加到deleted表中原来表的相应记录被删除所以在deleted表中查看删除的记录。
--创建delete触发器
create trigger trig_delete
on student
after delete
as
beginselect stu_id as 已删除的学生编号,stu_name stu_gender,stu_agefrom deleted
end; --执行一一条delete语句触发trig_delete触发器
delete from student where stu_id1;
结果如下 3.创建UPDATE触发器 update触发器是当用户在指定表上执行update语句时被调用被调用这种类型的触发器用来约束用户对数据的修改。update触发器可以执行两种操作更新前的记录存储在deleted表中更新后的记录存储在inserted表中。
--创建update触发器
create trigger trig_update
on student
after update
as
begindeclare stuCount int;select stuCountcount(*) from student;update student_sum set stuCount stuCount;select stu_id as 更新前学生编号,stu_name as 更新前学生姓名 from deletedselect stu_id as 更新后学生编号,stu_name as 更新后学生姓名 from inserted
end --创建完成执行一条update语句触发trig_update触发器
update student set stu_name张飞 where stu_id2; 4.创建替代触发器 与前面介绍的三种after触发器不同SqlServer服务器在执行after触发器的sql代码后先建立临时的inserted表和deleted表然后执行代码中对数据库操作最后才激活触发器中的代码。而对于替代(instead of)触发器,SqlServer服务器在执行触发instead of 触发器的代码时先建立临时的inserted表和deleted表然后直接触发instead of触发器而拒绝执行用户输入的DML操作语句。
--创建instead of 触发器
create trigger trig_insteadOf
on student
instead of insert
as
begindeclare stuAge int;select stuAge(select stu_age from inserted)
if(stuAge 120)select 插入年龄错误 as 失败原因
end 创建完成执行一条insert语句触发触发器trig_insteadOf 5.嵌套触发器介绍 如果一个触发器在执行操作时调用了另外一个触发器而这个触发器又接着调用了下一个触发器那么就形成了嵌套触发器。嵌套触发器在安装时就被启用但是可以使用系统存储过程sp_configure禁用和重新启用嵌套触发器。 嵌套触发器不一定要形成一个环它可以 T1-T2-T3...这样一直触发下去最多允许嵌套 32 层。如果嵌套的次数超过限制那么该触发器将被终止并回滚整个事务使用嵌套触发器需要注意以下几点
默认情况下嵌套触发器配置选项是开启的。在同一个触发器事务中一个嵌套触发器不能被触发两次。由于触发器是一个事务如果在一系列嵌套触发器的任意层次中发生错误则整个事物都将取消而且所有数据回滚。
嵌套是用来保持整个数据库的完整性的重要功能但有时可能需要禁用嵌套如果禁用了嵌套那么修改一个触发器的实现不会再触发该表上的任何触发器。在下述情况下需要禁用嵌套触发器
嵌套触发要求复杂而有理论的设计级联修改可能会修改用户不想涉及的数据。在一系列嵌套触发器中的任意点的时间修改操作都会触发一些触发器尽管这时数据库提供很强的保护功能但如果以特定的顺序更新表就会产生问题。
使用下列语句禁用嵌套和再次启用嵌套
--禁用嵌套
exce sp_configure nested triggers,0;
--启用嵌套
exce sp_configure nested triggers,1; 6.递归触发器 触发器的递归是指一个触发器从其内部再一次激活该触发器例如update操作激活的触发器内部还有一条数据表的更新语句那么这个更新语句就有可能激活这个触发器本身当然这种递归的触发器内部还会有判断语句只有一定情况下才会执行那个T_SQL语句否则就成为无线调用的死循环了。
SqlServer中的递归触发器包括两种直接递归和间接递归。
直接递归触发器被触发后并执行一个操作而该操作又使用一个触发器再次被触发。间接递归触发器被触发并执行一个操作而该操作又使另一个表中的某个触发器被触发第二个触发器使原始表得到更新从而再次触发第一个触发器。
默认情况下递归触发器选项是禁用的。递归触发器最多只能递归16层如果递归中的第16个触发器激活了第17个触发器则结果与发布的rollback命令一样所有数据都将回滚。
我们举例解释如下假如有表1、表2名称分别为 T1、T2在 T1、T2 上分别有触发器 G1、G2。
间接递归对 T1 操作从而触发 G1G1 对 T2 操作从而触发 G2G2 对 T1 操作从而再次触发 G1...直接递归对 T1 操作从而触发 G1G1 对 T1 操作从而再次触发 G1...
设置直接递归
默认情况下是禁止直接递归的要设置为允许有两种方法
T-SQLexec sp_dboption dbName, recursive triggers, trueEM数据库上点右键-属性-选项。 六:管理触发器
1.查看触发器
(1).查看数据库中所有的触发器
--查看数据库中所有的触发器
use 数据库名
go
select * from sysobjects where xtypeTR
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
exec 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]}ASsql_statement;
4.删除触发器
--语法格式:DROP TRIGGER { trigger } [ ,...n ]
参数:trigger: 要删除的触发器名称n:表示可以删除多个触发器的占位符