快捷搜索:

SQL Server数据库技术(76)

从以上的先容中我们可以看出触发用具有强大年夜的功能,那么MS SQL Server 是若何治理触发器来完成这些义务呢?下面我们将对其事情道理及实现做较为具体的先容。

每个触发器有两个特殊的表:插入表和删除表。这两个表是逻辑表,并且这两个表是由系统治理的,存储在内存中,不是存储在数据库中,是以不容许用户直接对其改动。这两个表的布局老是与被该触发器感化的表有相同的表布局。这两个表是动态驻留在内存中的,当触发器事情完成,这两个表也被删除。这两个表主要保存因用户操作而被影响到的原数据值或新数据值。别的,这两个表是只读的,即用户不能向这两个表写入内容,但可以引用表中的数据。例如可用如下语句查看DELETED 表中的信息:

select * from deleted

下面具体先容这两个表的功能:

12.7.1 插入表的功能

对一个定义了插入类型触发器的表来讲,一旦对该表履行了插入操作,那么对向该表插入的所有行来说,都有一个响应的副本寄放到插入表中。即插入表便是用来存储向原表插入的内容。

12.7.2 删除表的功能

对一个定义了删除类型触发器的表来讲,一旦对该表履行了删除操作,则将所有的删除行寄放至删除表中。这样做的目的是,一旦触发器碰到了逼迫它中止的语句被履行时,删除的那些行可以从删除表中得以规复。

必要强调的是,更新操作包括两个部分,即先将更新的内容去掉落,然后将新值插入。是以对一个定义了更新类型触发器的表来讲,当申报会更新操作时,在删除表中寄放了旧值,然后在插入表中寄放新值。

因为触发器仅当被定义的操作被履行时才被激活,即仅当在履行插入、删除、和更新操作时,触发器将履行。每条SQL 语句仅能激活触发器一次,可能存在一条语句影响多笔记录的环境。在这种环境下就必要变量@@rowcount 的值,该变量存储了一条SQL 语句履行后所影响的记录数,可以应用该值对触发器的SQL 语句履行后所影响的记录求合计值。一样平常来说,首先要用IF 语句测试@@rowcount 的值以确定后面的语句是否履行。

您可能还会对下面的文章感兴趣: