我是靠谱客的博主 兴奋金鱼,最近开发中收集的这篇文章主要介绍sql中触发器的使用,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

insert触发器的工作过程
     当触发INSERT触发器时, 新的数据行就会被插入到触发器表和inserted表中。inserted表是一个逻辑表,它包含了已经插入的 数据行的一个副本。inserted表包含了INSERT语句中已记录的插入动作。inserted表还允许引用由初始化INSERT语句而产生的日志数据。触发器通过检查inserted表来确定是否执行触发器动作或如何执行它。inserted表中的行总是触发器表中一行或多行的副本。

     创建一个触发器。无论何时订购产品(无论何时向Order Details表中插入一条记录),这个触发器都将更新Products表中的一列(UnitsInStock)。用原来的值减去订购的数量值即为新值。
     USE Northwind
     CREATE TRIGGER OrdDet_Insert
     ON [Order Details]
     FOR INSERT
     AS
     UPDATE P SET
     UnitsInStock = P.UnitsInStock – I.Quantity
     FROM Products AS P INNER JOIN Inserted AS I
     ON P.ProductID = I.ProductID

DELETE触发器的工作过程
  当触发DELETE 触发器后,从受影响的表中删除的行将被放置到一个特殊的deleted表中。deleted表是一个逻辑表,它保留已被删除数据行的一个副本。deleted表还允许引用由初始化DELETE语句产生的日志数据。
  使用DELETE触发器时,需要考虑以下的事项和原则:
  ·当某行被添加到deleted表中时,它就不再存在于数据库表中; 因此,deleted表和数据库表没有相同的行。
  ·创建deleted表时,空间是从内存中分配的。deleted表总是被存储在高速缓存中

        创建一个触发器,无论何时删除一个产品类别(即从Cate gories表中删除一条记录),该触发器都会更新Products表中的Discontinued列。所有受影响的产品都标记为1,标示不再使用这些产品了。
        USE Northwind
        CREATE TRIGGER Category_Delete
        ON Categories
        FOR DELETE
        AS
        UPDATE P SET Discontinued = 1
        FROM Products AS P INNER JOIN deleted AS d
        ON P.CategoryID = d.CategoryID

UPDATE触发器的工作过程
  可将UPDATE语句看成两步操作:即捕获数据前像(before image)的DELETE语句,和捕获数据后像(after image)的INSERT语句。当在定义有触发器的表上执行UPDATE语句时,原始行(前像)被移入到deleted表 ,更新行(后像) 被移入到inserted表。
  触发器检查deleted表和inserted表以及被更新的表,来确定是否更新了多行以及如何执行触发器动作。
  可以使用IF UPDATE语句定义一个监视指定列的数据更新的触发器。这样,就可以让触发器容易的隔离出特定列的活动。当它检测到指定列已经更新时,触发器就会进一步执行适当的动作,例如发出错误信息指出该列不能更新,或者根据新的更新的列值执行一系列的动作语句。
        本例阻止用户修改Employees表中的EmployeeID列。
        USE Northwind
        GO
        CREATE TRIGGER Employee_Update
        ON Employees
        FOR UPDATE
        AS
        IF UPDATE (EmployeeID)
        BEGIN
        RAISERROR ('Transaction cannot be processed.
        ***** Employee ID number cannot be modified.', 10, 1)
        ROLLBACK TRANSACTION //不提交事务,进行事务回滚
        END

多功能触发器
        A. 使用带有提醒消息的触发器
        当有人试图在 titles 表中添加或更改数据时,下例将向客户端显示一条消息。
        说明    消息 50009 是 sysmessages 中的用户定义消息。
        USE pubs
        IF EXISTS (SELECT name FROM sysobjects
                WHERE name = 'reminder' AND type = 'TR')
        DROP TRIGGER reminder
        GO
        CREATE TRIGGER reminder
        ON titles
        FOR INSERT, UPDATE
        AS RAISERROR (50009, 16, 10)
        GO


         B.使用带有提醒电子邮件的触发器
         当 titles 表更改时,下例将电子邮件发送给指定的人员 (MaryM)。

         USE pubs
         IF EXISTS (SELECT name FROM sysobjects
                    WHERE name = 'reminder' AND type = 'TR')
         DROP TRIGGER reminder
         GO
         CREATE TRIGGER reminder
         ON titles
         FOR INSERT, UPDATE, DELETE
         A*
         **EC master..xp_sendmail 'MaryM',
                 'Don''t forget to print a report for the distributors.'
         GO

最后

以上就是兴奋金鱼为你收集整理的sql中触发器的使用的全部内容,希望文章能够帮你解决sql中触发器的使用所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(56)

评论列表共有 0 条评论

立即
投稿
返回
顶部