SQL Server 构架  
触发器
Microsoft® SQL Server™ 2000 触发器是一类特殊的存储过程,被定义为在对表或视图发出 UPDATE、INSERT 或 DELETE 语句时自动执行。触发器是功能强大的工具,使每个站点可以在有数据修改时自动强制执行其业务规则。触发器可以扩展 SQL Server 约束、默认值和规则的完整性检查逻辑,但只要约束和默认值提供了全部所需的功能,就应使用约束和默认值。表可以有多个触发器。CREATE TRIGGER 语句可以与 FOR UPDATE、FOR INSERT 或 FOR DELETE 子句一起使用,指定触发器专门用于特定类型的数据修改操作。当指定 FOR UPDATE 时,可以使用 IF UPDATE (column_name) 子句,指定触发器专门用于具体某列的更新。触发器可使公司的处理任务自动进行。在库存系统内,更新触发器可以检测什么时侯库存下降到了需要再进货的量,并自动生成给供货商的定单。在记录工厂加工过程的数据库内,当某个加工过程超过所定义的安全限制时,触发器会给操作员发电子邮件或寻呼。无论何时只要有新的标题添加到 pubs 数据库中,下面的触发器就会生成电子邮件:CREATE TRIGGER reminder
ON titles
FOR INSERT
AS
   EXEC master..xp_sendmail 'MaryM',
      'New title, mention in the next report to distributors.'触发器包含 Transact-SQL 语句,这与存储过程十分相似。与存储过程一样,触发器也返回由触发器内的 SELECT 语句生成的结果集。不建议在触发器中包含 SELECT 语句,但仅填充参数的语句除外。这是因为用户不期望看到由 UPDATE、INSERT 或 DELETE 语句返回的结果集。可使用 FOR 子句指定触发器的执行时间: AFTER 
触发器在触发它们的语句完成后执行。如果该语句因错误(如违反约束或语法错误)而失败,触发器将不会执行。不能为视图指定 AFTER 触发器,只能为表指定该触发器。可以为每个触发操作(INSERT、UPDATE 或 DELETE)指定多个 AFTER 触发器。如果表有多个 AFTER 触发器,可使用 sp_settriggerorder 定义哪个 AFTER 触发器最先激发,哪个最后激发。除第一个和最后一个触发器外,所有其它的 AFTER 触发器的激发顺序不确定,并且无法控制。在 SQL Server 2000 中 AFTER 是默认触发器。不能在 SQL Server 7.0 版或更早的版本中指定 AFTER 或 INSTEAD OF,这些版本中的所有触发器都作为 AFTER 触发器运行。INSTEAD OF 
该触发器代替触发操作执行。可在表和视图上指定 INSTEAD OF 触发器。只能为每个触发操作(INSERT、UPDATE 和 DELETE)定义一个 INSTEAD OF 触发器。INSTEAD OF 触发器可用于对 INSERT 和 UPDATE 语句中提供的数据值执行增强的完整性检查。INSTEAD OF 触发器还允许指定某些操作,使一般不支持更新的视图可以被更新。
请参见用触发器强制执行业务规则©1988-2000 Microsoft Corporation。保留所有权利。

解决方案 »

  1.   

    搞清楚这些就行了.1.触发器的内容和存储过程一样,都是将一些数据处理命令放在一齐执行
      不同的是:存储过程中调用它时才执行,触发器在对表中的数据进行操作时被自动调用2.在何时(那种操作时)会执行触发器
    这个由for语句决定.
    for insert 代表插入数据时
    for update 代表更新数据时
    for delete 代表删除数据时
    insert update delete可以组合.例如:for insert,update 表示新增或更新数据时3.得到操作影响的数据,由inserted和deleted这两个逻辑表得到,结果与原表完全一样
    inserted  新增的数据,或更新操作时,更新后的数据
    deleted   删除的数据,或更新操作时,更新前的数据 --引用邹建