第十章 触发器

触发器是一种特殊的存储过程,常常用于实现强制业务规则和数据完整性。

10.1 触发器的创建与管理

触发器由SQL Server自动执行,不能由应用程序调用,这是它与存储过程不同的地方,便于保护数据库的完整性和完全性。

触发器在对表进行操作时(UPDATE、INSERT 或 DELETE)激活。

使用触发器有如下优点: 。

  • 触发器是自动的:它们在对表的数据作了任何修改(比如手工输入或者应用程序采取的操作)之后立即被激活。

  • 触发器可以通过数据库中的相关表进行层叠更改。这比直接把代码写在前台的做法更安全合理。

  • 触发器可以强制限制,这些限制比用 CHECK 约束所定义的更复杂。与 CHECK 约束不同的是,触发器可以引用其它表中的列

10.1.2 创建触发器

触发器用CREATE TRIGGER语句创建。语法如下:

CREATE TRIGGER trigger_name
ON { table | view }
[ WITH ENCRYPTION ]
{
    { { FOR | AFTER | INSTEAD OF } { [ INSERT ] [ , ] [ UPDATE ] }
        [ WITH APPEND ]
        [ NOT FOR REPLICATION ]
        AS
        [ { IF UPDATE ( column )
            [ { AND | OR } UPDATE ( column ) ]
                [ ...n ]
        | IF ( COLUMNS_UPDATED ( ) { bitwise_operator } updated_bitmask )
                { comparison_operator } column_bitmask [ ...n ]
        } ]
        sql_statement [ ...n ]
    }
}  

Microsoft 不支持在系统表上添加用户定义触发器。

CREATE TABLE Company(
		CompanyID  varchar (10) NOT NULL ,
              CompanyName varchar (30) NOT NULL
                    )     
CREATE TABLE Contract (
		ContractID varchar (10) NOT NULL ,
		CompanyID varchar (10) NOT NULL ,
		ContractName varchar (30) NULL ,
		ContractVolume numeric(18, 2) NULL,
		SignDate Datetime NULL)

	CREATE TABLE ContractDetail (
		ContractID varchar (10) NOT NULL ,
		ContractDetailID varchar (10) NOT NULL ,
		Volume numeric(18, 2) NULL)
		
CREATE TRIGGER attetion
ON Company
FOR INSERT, UPDATE, DELETE 
AS
EXEC master..xp_sendmail 'RED', ‘公司信息表已发生变化!’

10.1.3 修改和删除触发器

--修改触发器用ALTER TRIGGER,语法如下:
ALTER TRIGGER trigger_name 
ON ( table | view ) 
[ WITH ENCRYPTION ] 
{ 
    { ( FOR | AFTER | INSTEAD OF ) { [ DELETE ] [ , ] [ INSERT ] [ , ] [ UPDATE ] } 
        [ NOT FOR REPLICATION ]
        AS
        sql_statement [ ...n ]
    } 
    | 
    { ( FOR | AFTER | INSTEAD OF ) { [ INSERT ] [ , ] [ UPDATE ] }
        [ NOT FOR REPLICATION ]
        AS
        { IF UPDATE ( column )
        [ { AND | OR } UPDATE ( column ) ]
        [ ...n ]
        | IF ( COLUMNS_UPDATED ( ) { bitwise_operator } updated_bitmask )
        { comparison_operator } column_bitmask [ ...n ]
        } 
        sql_statement [ ...n ] 
    } 
}

Last updated