sqlserver触发器学习

一、触发器的概念

       SQL Server提供两种主要机制来强制使用业务规则和数据完整性,即约束和触发器。

       触发器是一种特殊类型的存储过程,当指定表中的数据发生变化时触发器自动生效。它与表紧密相连,可以看作是表定义的一部分。触发器不能通过名称被直接调用,更不允许设置参数。

       在 SQL Server中一张表可以有多个触发器。用户可以使用 INSERT、 UPDATE或 DELETE语句对触发器进行设置,也可以对一张表上的特定操作设置多个触发器。触发器可以包含复杂的 Transact-SQL语句。不论触发器所进行的操作有多复杂,触发器都只作为一个独立的单元被执行,被看作是一个事务。如果在执行触发器的过程中发生了错误,则整个事务将会自动回滚。 

 二、触发器的优点

      触发器的优点表现在以下几个方面:

  1. 触发器自动执行,对表中的数据进行修改后,触发器立即被激活。
  2. 为了实现复杂的数据库更新操作,触发器可以调用一个或多个存储过程,甚至可以通过调用外部过程(不是数据库管理系统本身)完成相应的操作。
  3. 触发器能够实现比 CHECK约束更为复杂的数据完整性约束。在数据库中,为了实现数据完整性约束,可以使用 CHECK约束或触发器。 CHECK约束不允许引用其他表中的列来完成检查工作而触发器可以引用其他表中的列。触发器更适合在大型数据库管理系统中用来约束数据的完整性
  4. 触发器可以检测数据库内的操作,从而取消了数据库未经许可的更新操作,使数据库修改、更新操作更安全,数据库的运行也更稳定
  5. 触发器能够对数据库中的相关表实现级联更改。触发器是基于一个表创建的,但是可以针对多个表进行操作,实现数据库中相关表的级联更改。
  6. 一个表中可以同时存在3个不同操作的触发器( INSERT、 UPDATE和 DELETE)。 

 三、触发器的种类

1.DML触发器 

         当数据库中发生数据操作语言(DML)事件时将调用DML触发器。DML事件包括在指定表或视图中修改数据的 INSERT语句、 UPDATE语句或 DELETE语句。DML触发器可以查询其他表,还可以 包含复杂的 Transact-SQL语句。
用户可以设计以下类型的DML触发器。

  • AFTER(FOR)触发器:在执行了 INSERT、 UPDATE或 DELETE语句操作之后执行 AFTER触发器。
  • INSTEAD OF触发器:执行 INSTEAD OF触发器代替通常的触发动作。还可为带有一个或多个基表的视图定义 INSTEAD OF触发器,而这些触发器能够扩展视图可支持的更新类型。INSTEAD OF触发器只能存在一个,例:INSTEAD OF UPDATE不能存在两个。
  • CLR触发器:CLR触发器可以是 AFTER触发器或 INSTEAD OF触发器。CLR触发器还可以是DDL触发器。CLR触发器将执行在托管代码(在 NET Framework中创建并在 SQL Server中上载的程序集的成员)中编写的方法,而不用执行 Transact-SQL存储过程。

PS: (1)AFTER先执行增删改操作,再执行触发器操作; INSTEAD OF直接只执行触发器里的。

       (2)触发器会产生两张表inserted(语句执行后的受影响的数据表),deleted(受影响语句执行前的数据表),这两张表会                    保存中间过度数据,存在内存里,等触发器执行完后就释放。这两张表都只是缓存,不表示实际的数据表。

2.DDL触发器

        DDL触发器用于响应各种数据定义语言(DDL)事件。这些事件主要对应于 Transact-SQL CREATE 、ALTER和DROP语句,以及执行类似DDL操作的某些系统存储过程 。

3.登录触发器 

       登录触发器在遇到 LOGON事件时触发。 LOGON事件是在建立用户会话时引发的。触发器可以由Transact-SQL语句直接创建,也可以由程序集方法创建,这些方法是在 Microsoft. NET Framework公共语言运行时(CLR)中创建并上载到 SQL Server实例的。 SQL Server允许为任何特定语句创建多个触发器 。

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
sqlserver触发器例子 一﹕ 触发器是一种特殊的存储过程﹐它不能被显式地调用﹐而是在往表中插入记录﹑更新记录或者删除记录时被自动地激活。所以触发器可以用来实现对表实施复杂的完整性约`束。 二﹕ SQL Server为每个触发器都创建了两个专用表﹕Inserted表和Deleted表。这两个表由系统来维护﹐它们存在于内存中而不是在数据库中。这两个表的结构总是与被该触发器作用的表的结构相同。触发器执行 完成后﹐与该触发器相关的这两个表也被删除。 Deleted表存放由于执行Delete或Update语句而要从表中删除的所有行。 Inserted表存放由于执行Insert或Update语句而要向表中插入的所有行。 三﹕Instead of 和 After触发器 SQL Server2000提供了两种触发器﹕Instead of 和After 触发器。这两种触发器的差别在于他们被激活的同﹕ Instead of触发器用于替代引起触发器执行的T-SQL语句。除表之外﹐Instead of 触发器也可以用于视图﹐用来扩展视图可以支持的更新操作。 After触发器在一个Insert,Update或Deleted语句之后执行﹐进行约束检查等动作都在After触发器被激活之前发生。After触发器只能用于表。 一个表或视图的每一个修改动作(insert,update和delete)都可以有一个instead of 触发器﹐一个表的每个修改动作都可以有多个After触发器。 四﹕触发器的执行过程 如果一个Insert﹑update或者delete语句违反了约束﹐那幺After触发器不会执行﹐因为对约束的检查是在After触发器被激动之前发生的。所以After触发器不能超越约束。 Instead of 触发器可以取代激发它的操作来执行。它在Inserted表和Deleted表刚刚建立﹐其它任何操作还没有发生时被执行。因为Instead of 触发器在约束之前执行﹐所以它可以对约束进行一些预处理。 五﹕使用T-SQL语句来创建触发器 基本语句如下﹕ create trigger trigger_name on {table_name | view_name} {for | After | Instead of } [ insert, update,delete ] as sql_statement 六﹕相关示例﹕ 1﹕在Orders表中建立触发器﹐当向Orders表中插入一条订单记录时﹐检查goods表的货品状态status是否为1(正在整理)﹐是﹐则不能往Orders表加入该订单。 create trigger orderinsert on orders after insert as if (select status from goods,inserted where goods.name=inserted.goodsname)=1 begin print 'the goods is being processed' print 'the order cannot be committed' rollback transaction --回滚﹐避免加入 end 2﹕在Orders表建立一个插入触发器﹐在添加一条订单时﹐减少Goods表相应的货品记录中的库存。 create trigger orderinsert1 on orders after insert as update goods set storage=storage-inserted.quantity from goods,inserted where goods.name=inserted.goodsname 3﹕在Goods表建立删除触发器﹐实现Goods表和Orders表的级联删除。 create trigger goodsdelete on goods after delete as delete from orders where goodsname in (select name from deleted) 4﹕在Orders表建立一个更新触发器﹐监视Orders表的订单日期(OrderDate)列﹐使其不能手工修改. create tri

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Bridge_go

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值