前言:
触发器与存储过程有一点点差别的,那么我们什么时候要用触发器,接下来将给大家揭晓!
1、什么是触发器
触发器是一个在修改指定表中的数据执行的存储过程。通常通过创建触发器来强制实现 不同表 中的逻辑相关数据的引用完整性或一致性。由于用户不能绕过触发器,所以用来 强制实施复杂的业务规则!以此确保数据的 完整性 !
一开始以为触发器没什么总结的,但是通过系统的学习,发现还是有必要总结一下的,接下来将是几篇触发器的总结博客!
2、为什么要使用触发器
(1)触发器自动执行,他们在表的数据做了任何修改,之后立即激活!(和事件差不多了)
(2)触发器可以通过数据库中的相关表进行层叠更改,这直接把代码写在客户端更加合理!
(3)触发器的限制可以引用到其它表中的列!
3、触发器如何保证数据的完整性
个人理解:比如我们做牛腩新闻系统的时候,如果我们删除了一条新闻,那么删除这条新闻的时候,它下面的新闻的评论也随之删除,此时涉及到两个表,一个是新闻表,一个是评论表!如果没有触发器的话,我们在程序中还要加上删除新闻评论表中的对应的内容!但是有时候程序员万一要是忘记设计删除新闻评论类,那么数据就不完整了!(新闻表中没有了此类新闻,但是评论表中却有此类新闻的评论!)
4、触发器的种类
我们之前设计的触发器好像都是DML的,但是还有DDL,那么二者之间有何区别呢!
DML触发器(修改表中的数据用)
DML(Data Manipulation Language)触发器是当数据库中发生数据操作语言事件要执行的操作。它通常包含三种:INSERT触发器,UPDATE触发器,DELETE触发器!当我们要对 数据库里的数据 进行操作的时候,我们要用到DML触发器!
DDL触发器(修改表)
DDL触发器是当数据库中发生数据定义语言(Data Definition Language)主要包括CREATE,ALTER,DROP等操作!当我们用在 定义或者改变表的结构,数据类型,表之间的连接和约束的时候,我们就用DDL触发器!
触发器保证了我们数据库数据的完整性,DDL是修改表的层次,DML是修改表中的数据层次!
5、触发器类型 FOR 、AFTER、 Instead of到底是什么
由于FOR触发器与AFTER触发器是一个作用,所以触发器分为AFTER触发器,与Instead of 触发器!
为了让大家明白触发器,我先把我的数据库是干嘛的给大家介绍一下吧,我的数据库是一个新闻发系统对应的数据库 ,里边有两个表一个是新闻类别表caregory ,还有一个是新闻表news,其中一条类新闻对应多条新闻,但是一条新闻只是属于一类!故有下图!其中news表的主键为id,外键为caID,与care gory的主键相对,此时通过主外键将两个表连接起来!
接下来我们要完成的操作是删除表中一条新闻类别信息,我们此时建立一条delete触发器,通过这个触发器我们来了解一下AFTER触发器与instead of 触发器之间到底有何区别!
6、AFTER(for)触发器 (操作后)
after触发器是指在操作成功后,所采取的一些动作!
比如:下面是我创建好的一个after触发器
<span style="color:#000000"><code>SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
creat trigger [dbo].[T_CaregoryDelete] --触发器的名字为T_CaregoryDelete
on [dbo].[caregory] --是caregory类别表的触发器
after delete --after代表执行删除后执行as后边的语句
as
begin
delete news where caId=(select id from deleted) --激发触发器后我要执行的动作,其中deleted是一个系统默认临时表
end
</code></span>
接下来我编译代码
delete from caregory where id=4,报了如下的错误!
刚才我说过了,我们的类别表caregory与新闻表news表是通过主外键连接的,我们在执行语句delete from caregory where id=4的时候我们的news表对应的新闻也应该被删除!如下所示图!
但是我们的after触发器只能是在执行完delete操作后执行,如果此时我们执行
delete from caregory where id=4 ,那么我们将我们id信息为4的类别的新闻删除后才可以触发触发器,那么我们的这类新闻下的所有新闻就不能被删除了,这时候我们的表是主外键连接的,所以就报了上述错误!那么这下该怎么办呢,这时候解决instead of 触发器登场!
2、instead of 触发器
对数据的操作只是一个“导火索”而已,真正起作用的是触发器里面的动作;往往这种触发器会有很多分支判断语句在里面,根据不用的条件做不同的动作!
INSTEAD OF 触发器用来代替通常的触发动作,即当对表进行INSERT、UPDATE 或 DELETE 操作时,系统不是直接对表执行这些操作,而是把操作内容交给触发器,让触发器检查所进行的操作是否正确。如正确才进行相应的操作。因此,INSTEAD OF 触发器的动作要早于表的约束处理。
真正起作用的是触发器里面的动作,接下来是对应触发器的代码
<span style="color:#000000"><code>SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER trigger [dbo].[T_CaregoryDelete]
on [dbo].[caregory]
instead of delete
as
begin
delete news where caId=(select id from deleted)
delete caregory where id=(select id from deleted)
end
</code></span>
此时执行语句delete from caregory where id=4,那么我们就成功的将我们类别表信息删除,同时将我们类别表下对应的这类的新闻页一块删除了!
这里可能有人就有疑问了,算上delete from caregory where id=4 共有三个delete,注意上面我强调了一句话,真正起作用的是触发器里面的动作!
后记:
after触发器是在操作成功后,所采取的一些动作
而对于instead of触发器,真正起作用的是触发器里面的动作!
文章转载于:https://blog.csdn.net/jerry11112/article/details/82928739