文章目录[隐藏]
Sql触发器(如何编写sql数据库触发器)
触发器是SQL server提供给程序员和数据分析师的一种确保数据完整性的方法。它是一个与表事件相关的特殊存储过程。它的执行不是由程序调用或手动启动,而是由事件触发。当一个表被操作(插入、删除、更新)时,它将被激活。触发器通常用于实施数据完整性约束和业务规则。
一、触发器的优点
1.触发是自动的。对表中的数据进行任何更改后,它会立即被激活。
2.数据库中的相关表可以级联修改触发器。
3.触发器可以实施限制。这些限制比检查约束定义的限制更复杂。与CHECK约束不同,触发器可以引用其他表中的列。
二。触发器的分类
SqlServer包括三种常规类型的触发器:DML触发器、DDL触发器和登录触发器。
1.DML(数据操作语言)触发器
DML触发器是附加到特定表或视图的一些操作码,当数据库服务器中发生数据操作语言事件时执行这些操作码。SqlServer中有三种类型的DML触发器:
触发器:当数据插入到表中时触发;
删除触发器:从表中删除数据时触发;
更新触发器:当表中的数据被修改时触发。
当您遇到以下情况时,应该考虑使用DML触发器:
通过数据库中的相关表级联更改
防止恶意或错误的插入、更新和删除操作,并使用由检查约束定义的更复杂的限制来实施其他限制。
评估数据修改前后的表的状态,并根据差异采取措施。
2.DDL(数据定义语言)触发器
当服务器或数据库中发生数据定义语言(主要是以create、drop、alter alter开头的语句)事件时,将激活并使用DDL触发器。使用DDL触发器可以防止对数据架构的某些更改,或者记录数据中的更改或事件操作。
3.登录触发器
登录触发器触发存储过程以响应登录事件。当与SQL Server实例建立用户会话时,会引发此事件。登录触发器将在登录的身份验证阶段完成之后、用户会话实际建立之前触发。因此,来自触发器内部并通常到达用户的所有消息(如错误消息和来自PRINT语句的消息)都将被传输到SQL Server错误日志。如果身份验证失败,将不会触发登录触发器。
三、触发器的工作原理
【删除、插入、更新】对应删除、插入、更新时触发。
执行insert时,获取插入的数据,可以通过select*from inserted读取。
删除时,获取删除前的数据,可以通过select * from delete读取。
更新时,可以通过select *从删除中读取更新前的数据,通过select *从插入中读取更新后的数据。
四。创建触发器
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触发器create trigger trig_inserton studentafter insertasbegin 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触发器create trigger trig_deleteon student after deleteasbegin select stu_id as 已删除的学生编号,stu_name stu_gender,stu_age from deletedend;--执行一一条delete语句触发trig_delete触发器delete from student where stu_id=1;
4.创建更新触发器
当用户对指定的表执行Update语句时,将调用update触发器。这种类型的触发器用于限制用户对数据的修改。更新触发器可以执行两个操作:更新前的记录存储在删除的表中,更新后的记录存储在插入的表中。
--创建update触发器create trigger trig_updateon studentafter updateasbegin 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 insertedend--创建完成,执行一条update语句触发trig_update触发器update student set stu_name=\'张飞\' where stu_id=2;
动词 (verb的缩写)管理触发器
1.检查扳机
(1).检查数据库中的所有触发器。
--查看数据库中所有的触发器use 数据库名goselect * from sysobjects where xtype=\'TR\'
Sysobjects保存数据库的对象,其中xtype TR的记录是触发器对象。在name列中,我们可以看到触发器名称。
(2).sp_helptext以查看触发器内容
use 数据库名goexec sp_helptext \'触发器名称\'
触发内容将以表格形式显示。
除了触发器之外,sp_helptext还可以显示规则、默认值、未加密的存储过程、用户定义的函数和视图的文本。
(3).sp_helptrigger用于查看触发器的属性。
Sp_helptrigger有两个参数:第一个参数是表名;第二个是触发器类型,它是char(6),可以是INSERT、UPDATE或DELETE。如果省略,将显示指定表中所有类型触发器的属性。
以上就是由优质生活领域创作者 嘉文社百科网小编 整理编辑的,如果觉得有帮助欢迎收藏转发~
本文地址:https://www.jwshe.com/580476.html,转载请说明来源于:嘉文社百科网
声明:本站部分文章来自网络,如无特殊说明或标注,均为本站原创发布。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。分享目的仅供大家学习与参考,不代表本站立场。