问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

sql server 2005在使用触发器时,INSERTED表和DELETED表的作用是什么?

发布网友 发布时间:2022-10-12 15:04

我来回答

2个回答

热心网友 时间:2023-10-22 15:20

可以定义一个无论何时用INSERT语句向表中插入数据时都会执行的触发器。

当触发INSERT触发器时,新的数据行就会被插入到触发器表和inserted表中。inserted表是一个逻辑表,它包含了已经插入的数据行的一个副本。inserted表包含了INSERT语句中已记录的插入动作。inserted表还允许引用由初始化INSERT语句而产生的日志数据。触发器通过检查inserted表来确定是否执行触发器动作或如何执行它。inserted表中的行总是触发器表中一行或多行的副本。

日志记录了所有修改数据的动作(INSERT、UPDATE和DELETE语句),但在事务日志中的信息是不可读的。然而,inserted表允许你引用由INSERT语句引起的日志变化,这样就可以将插入数据与发生的变化进行比较,来验证它们或采取进一步的动作。也可以直接引用插入的数据,而不必将它们存储到变量中。

示例

在本例中,将创建一个触发器。无论何时订购产品(无论何时向Order Details表中插入一条记录),这个触发器都将更新Procts表中的一列(UnitsInStock)。用原来的值减去订购的数量值即为新值。

USE Northwind
CREATE TRIGGER OrdDet_Insert
ON [Order Details]
FOR INSERT
AS
UPDATE P SET
UnitsInStock = P.UnitsInStock – I.Quantity
FROM Procts AS P INNER JOIN Inserted AS I
ON P.ProctID = I.ProctID

DELETE触发器的工作过程

当触发DELETE触发器后,从受影响的表中删除的行将被放置到一个特殊的deleted表中。deleted表是一个逻辑表,它保留已被删除数据行的一个副本。deleted表还允许引用由初始化DELETE语句产生的日志数据。

使用DELETE触发器时,需要考虑以下的事项和原则:

·当某行被添加到deleted表中时,它就不再存在于数据库表中;因此,deleted表和数据库表没有相同的行。

·创建deleted表时,空间是从内存中分配的。deleted表总是被存储在高速缓存中。

·为DELETE动作定义的触发器并不执行TRUNCATE TABLE语句,原因在于日志不记录TRUNCATE TABLE语句。

示例 在本例中,将创建一个触发器,无论何时删除一个产品类别(即从Categories表中删除一条记录),该触发器都会更新Procts表中的Discontinued列。所有受影响的产品都标记为1,标示不再使用这些产品了。

USE Northwind
CREATE TRIGGER Category_Delete
ON Categories
FOR DELETE
AS
UPDATE P SET Discontinued = 1
FROM Procts AS P INNER JOIN deleted AS d
ON P.CategoryID = d.CategoryID

热心网友 时间:2023-10-22 15:21

DML 触发器语句使用两种特殊的表:删除的表和插入的表。SQL Server 2005 会自动创建和管理这两种表。您可以使用这两种驻留内存的临时表来测试特定数据修改的影响以及设置 DML 触发器操作条件。但不能直接修改表中的数据或对表执行数据定义语言 (DDL) 操作,例如 CREATE INDEX。

删除的表用于存储 DELETE 和 UPDATE 语句所影响的行的副本。在执行 DELETE 或 UPDATE 语句的过程中,行从触发器表中删除,并传输到删除的表中。删除的表和触发器表通常没有相同的行。

插入的表用于存储 INSERT 和 UPDATE 语句所影响的行的副本。在执行插入或更新事务过程中,新行会同时添加到 inserted 表和触发器表中。插入的表中的行是触发器表中的新行的副本。

更新事务类似于在删除操作之后执行插入操作;首先,旧行被复制到删除的表中,然后,新行被复制到触发器表和插入的表中。

在设置触发器条件时,应使用激发触发器的操作相应的插入的和删除的表。尽管在测试 INSERT 时引用删除的表或在测试 DELETE 时引用插入的表不会导致任何错误,但在这些情况下,这些触发器测试表将不包含任何行。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
手机puik什么意思 广东江南理工高级技工学校地址在哪里 广州市技师学院具体地址 广州市高级技工学校江高校区有什么专业 广州市高级技工学校学校地址 话费支付是什么意思? 2019年华为保值机型排行:P40系列保值预计如何? 鸦片战争的二号元凶:威廉·嘉道理 局域网内访问共享要密码 Win10怎么设置局域网共享密码访问 SQL触发器inserted问题 怎么查看触发器inserted表中的数据 inserted表存放增加的记录和什么 700可以买什么平板电脑? 社保,医保以及住房公积金的跨省转移问题 大众夏朗突然右前轮吱吱响是什么问题? 大众新夏朗熄火时伴随有异响怎么办 大众夏朗发动机正时链条哗啦哗啦响? 进口大众夏朗方向盘内咯吱咯吱响怎么解决 夏朗天窗异响怎么解决 2018款夏朗转向和发动机异响 夏朗主驾驶车玻璃异响 米粉怎么吃才好吃又简单 为什么前面板插孔检测会检测不到呢! 铭瑄主板电脑没有显示禁用前面板插孔检测? 完美解码是干什么的 完美解码是干嘛用的? 完美解码是什么?删除对电脑有没有影响? 压片时完美解码是用来干什么的? 完美解码到底是用来干嘛的?? 触发器 如何把inserted中的数据插入到另一个表 inserted、deleted在SQL Server中是什么意思? 2012SQLserver+触发器为什么用inserted找不到列名? 什么是微信分付 微信分付介绍 润字的音节是什么 润的音节是什么 滋润的润音节是什么 湿润中的润是什么音节 滋润的润字的音序在什么? 将三个二V的电池并联在一起可以得到一个六V的电压吗? 苏州银行新区支行营业时间 瀚银手付通刷了别人的卡钱出不来,不到账,怎么办,很急 我想问问有痘痘能做激光祛痘坑吗 冰箱发烫会爆炸吗 冰箱很烫能不能爆炸 盖碗茶是哪个民族的风俗 端午节屈原的成语 巫师归来那个职业 求伏地魔的文章bl bg 不限 越多越好 不要以第一人称讲述的 谢谢~~ 鱼鳞皮肤病图片啊?病者生这个鱼鳞症七年了;手臂上面有不少形状不规则的角化!冬重夏轻 仓鼠能不能吃麻花?