SQL Server触发器

Posted slgkaifa

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL Server触发器相关的知识,希望对你有一定的参考价值。

简介:  

  触发器事实上是一种特殊的存储过程。它仅仅有在特定的事件发生时自己主动运行。

存储过程和触发器都是SQL语句和流程控制语句的集合,存储过程通过存储过程的名字被直接调用。而触发器主要通过时间进行触发而被运行。

触发器的分类:

  触发器包含DML触发器和DDL触发器。DML触发器是我们常见的一种触发器,当数据库server中发生数据操作语言(DML)事件时会自己主动运行;DDL触发器是一种新型的触发器,它在响应数据定义语言(DDL)语句时触发。一般用于数据库中运行管理任务。今天我们主要研究DML触发器。它又分为AFTER触发器和INSTEAD OF触发器两类。

  AFTER触发器是记录已经改变完毕之后才被激活的运行。也就是事件已经结束触发器才被触发;INSTEAD OF触发器是用来代替原本的操作,在事件发生之前触发,这样它并不运行原先的SQL语句。而是依照触发器中的定义操作。

触发条件:

  DML触发器响应UPDATE、INSERT、DELETE语句而激活;DDL触发器响应CREATE、ALTER、DROP、GRANT、DENY、REVOKE、UPDATE以及STATISTICS等语句而激活。

思维导图:

  技术分享

创建触发器:

  技术分享

  技术分享

简单应用:

  以牛腩新闻公布系统中删除新闻类别同一时候删除新闻以及评论为例。这里由于有外键约束,所以删除新闻类别的同一时候要删除该类别的新闻以及评论。由于 AFTER触发器是记录已经改变完毕之后才被激活的运行,因此我们用INSTEAD OF触发器,把之前单纯的删除类别操作替换为删除评论、新闻以及类别的操作。

这样就不会出现外键约束而导致无法删除的情况了。

 

<span style="font-family:KaiTi_GB2312;font-size:18px;">-- =============================================
-- Author:		<邵鸿鑫>
-- Create date: <2014-8-18>
-- Description:	<删除类别触发器>
-- =============================================
ALTER TRIGGER [dbo].[trigCategoryDelete]
   ON [dbo].[category]
   instead of DELETE
AS 
BEGIN
	declare @caId int
	select @caId =id from deleted
	--删除评论
	delete comment where newsId in(select newsId  from news where caId [email protected] )
	--删除新闻
	delete news where [email protected] 
	--删除类别
	delete category where [email protected] 
END
</span>


触发器的作用:

  1)强制比CHECK约束更复杂的数据的完整性

  2)使用自己定义的错误提示信息
  3)实现数据库中多张表的级联改动
  4)比較数据库改动前后数据的状态
  5)调用很多其它的存储过程
  6)维护非规范化数据
触发器的长处还有非常多。须要我们到实际应用中去探索。以上有不足之处,希望大家批评指正。??
??


以上是关于SQL Server触发器的主要内容,如果未能解决你的问题,请参考以下文章

使用实体框架迁移时 SQL Server 连接抛出异常 - 添加代码片段

SQL Server——触发器

SQL server 如何调试触发器!

SQL Server T—SQL 存储过程 触发器

SQL server 建立的触发器子查询返回值不唯一,需要用多个返回值如何操作

sql server 触发器一个结果集变化更新到新表