SQL Server数据库技术(73)[MSSQL防范]
本文“SQL Server数据库技术(73)[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
从以上的介绍中我们可以看出触发器具有强盛的功效,那么MS sql server 是若何管理触发器来完成这些任务呢?下面我们将对其工作原理及实现做较为具体的介绍.
每个触发器有两个特别的表:插入表和删除表.这两个表是逻辑表,并且这两个表是由系统管理的,存储在内存中,不是存储在数据库中,因此不答应用户直接对其改正.这两个表的构造老是与被该触发器作用的表有相同的表构造.这两个表是动态驻留在内存中的,当触发器工作完成,这两个表也被删除.这两个表主要保存因用户操作而被影响到的原数据值或新数据值.别的,这两个表是只读的,即用户不能向这两个表写入内容,但可以引用表中的数据.比方可用以下语句查看DELETED 表中的信息:
select * from deleted
下面具体介绍这两个表的功效:
12.7.1 插入表的功效
对一个定义了插入范例触发器的表来说,一旦对该表履行了插入操作,那么对向该表插入的全部行来说,都有一个呼应的副本存放到插入表中.即插入表就是用来存储向原表插入的内容.
12.7.2 删除表的功效
对一个定义了删除范例触发器的表来说,一旦对该表履行了删除操作,则将全部的删除行存放至删除表中.这样做的目的是,一旦触发器碰到了逼迫它中止的语句被履行时,删除的那些行可以从删除表中得以恢复.
需求夸大的是,更新操作包含两个部份,即先将更新的内容去掉,然后将新值插入.因此对一个定义了更新范例触发器的表来说,当报告会更新操作时,在删除表中存放了旧值,然后在插入表中存放新值.
由于触发器仅当被定义的操作被履行时才被激活,即仅当在履行插入、删除、和更新操作时,触发器将履行.每条SQL 语句仅能激活触发器一次,大概存在一条语句影响多条记录的情形.在这种情形下就需求变量@@rowcount 的值,该变量存储了一条SQL 语句履行后所影响的记录数,可以利用该值对触发器的SQL 语句履行后所影响的记录求合计值.普通来说,首先要用IF 语句测试@@rowcount 的值以肯定背面的语句能否履行.
本文地址: | 与您的QQ/BBS好友分享! |