当前位置:Gxlcms > 数据库问题 > SQL 触发器

SQL 触发器

时间:2021-07-01 10:21:17 帮助过:26人阅读

    一、触发器的形成原因:

    1、完成预定义的一系列操作。对数据库进行某个操作后,系统能自动的根据条件转去执行各种操作,甚至执行与原操作无关的操作,那么,这个设想,可以用触发器来实现。我的理解是,从一方面来讲,触发器就是我们自己定义的一组SQL语句,用来对数据库进行操作。

    2、为了实现数据库的完整性,其中包括一些约束条件,像什么基本表约束啦等等。其目的就是保证数据的正确性(数据是否合法),有效性(数据是否属于定义的范围)、相容性(防止错误数据进入数据库)。

    二、 触发器的结构:

    1、事件:对数据进行的Insert 、Delete、Update 等操作

    2、条件:测试触发器成立的条件。

    3、动作:对数据库的一些操作。

    触发器的结构中还有动作时间即 AFTER 和 INSTEAD OF,AFTER表示在触发时间完成之后执行触发器的动作体部分,INSTEAD OF表示在触发时间发生时执行触发器的动作体部分。

    触发器的执行过程 如果一个Insert﹑update或者delete语句违反了约束﹐那幺After触发器不会执行﹐因为对约束的检查是在After触发器被激动之前发生的。所以After触发器不能超越约束。Instead of 触发器可以取代激发它的操作来执行。它在Inserted表和Deleted表刚刚建立﹐其它任何操作还没有发生时被执行。因为Instead of 触发器在约束之前执行﹐所以它可以对约束进行一些预处理。

    三、触发器中的表

    触发器有两个特殊的表,插入表(instered表)和删除表(deleted表)。这两张是逻辑表也是虚表。是系统在内存中创建者两张表,不会存储在数据库中。而且两张表的都是只读的,只能读取数据而不能修改数据。这两张表的结果总是与被改触发器应用的表的结构相同。当触发器完成工作后,这两张表就会被删除。Inserted表的数据是插入或是修改后的数据,而deleted表的数据是更新前的或是删除的数据。

技术分享

    四、触发器的一些操作

    1、创建

CREATE TRIGGER tgr_name --触发器的名字 
   ON  news --将要操作的表的名字 
   AFTER DELETE  -- 动作体在完成news表的删除操作之后执行
 AS 
BEGIN
    declare @caId int
	select @caId =id from deleted
	--删除评论
	delete comment where newsId in (select newsId from news where caId =@caId)
	--删除新闻
	delete news where caId =@caId
	--删除类别
	delete category where id=@caId

END
GO

   2、删除

 drop trigger trigger_name  
  五、小结

  以前学习过耿建玲老师的SQLServer视频,但是当时幼稚的我没有理解里面的奥秘,这才知道学习是一个反复的过程,这是后在看触发器,有了不一样的感觉,其实,触发器的应用还很多,我只是将自己理解的写了上来,欢迎广大读者丢转。

SQL 触发器

标签:数据库   sql server   

人气教程排行