inserted i,deleted d,学习成绩表 b i d b是别名
解决方案 »
- |zyciis| 如何在各种数据库语句中识别出数据库名称,谢谢
- SQL Server 索引结构及其使用【转】希望对大家有帮助!
- 确实是疯老,这是怎么一回事!邹建兄在哪里
- 数据库恢复问题~!请帮忙顶一下.
- 如何将两个表中的数据提取到一张表中
- 树结构的表,如何用sql 语句显示成这样的结果?
- 麻烦::sql server中怎样把一个超长的科学表达式的值转成自然数字的形式
- 请教使用Updategrams 模板向SQLSERVER2000更新数据时不支持中文怎么办?
- MSSQL SERVER 同步复制 的一个错误信息 Cann't get lience infomation?
- SQL SERVER2012自动增长列,值跳跃问题(自增增加1000)
- 我想在存储过程实现这样的功能不知用什么函数?
- 请各位高手帮忙,分布式查询问题
产生两个临时表
INSERTED修改后的记录
DELETED修改前的记录
D。B是表的别名
D代表deleted
B代表学习成绩表
set 姓名=i.姓名
from inserted i,deleted d,学习成绩表 b
where d.姓名=b.姓名
and d.id=i.id==>>
---这个没用别名:update 学习成绩表
set 姓名=inserted.姓名
from inserted,deleted
where deleted.姓名=学习成绩表.姓名
and deleted.id=inserted.id
==>update 学习成绩表set 姓名=别名1.姓名 <<=====这里呀!from inserted 别名1, <<=====这里deleted 别名2,学习成绩表 别名3
where 别名2.姓名=别名3.姓名
and 别名2.id=别名1.id
create table 表 (a int)
go
insert 表 values (1)
go
CREATE TRIGGER 名 ON 表
FOR UPDATE
AS
select a 更新前被删除的数据 from deleted
select a 更新后被插入的数据 from inserted
go
------------测试:
update 表 set a=3
触发器语句中使用了两种特殊的表:deleted 表和 inserted 表。Microsoft® SQL Server™ 2000 自动创建和管理这些表。可以使用这两个临时的驻留内存的表测试某些数据修改的效果及设置触发器操作的条件;然而,不能直接对表中的数据进行更改。inserted 和 deleted 表主要用于触发器中: 扩展表间引用完整性。
在以视图为基础的基表中插入或更新数据。
检查错误并基于错误采取行动。
找到数据修改前后表状态的差异,并基于此差异采取行动。
Deleted 表用于存储 DELETE 和 UPDATE 语句所影响的行的复本。在执行 DELETE 或 UPDATE 语句时,行从触发器表中删除,并传输到 deleted 表中。Deleted 表和触发器表通常没有相同的行。Inserted 表用于存储 INSERT 和 UPDATE 语句所影响的行的副本。在一个插入或更新事务处理中,新建行被同时添加到 inserted 表和触发器表中。Inserted 表中的行是触发器表中新行的副本。更新事务类似于在删除之后执行插入;首先旧行被复制到 deleted 表中,然后新行被复制到触发器表和 inserted 表中。在设置触发器条件时,应当为引发触发器的操作恰当使用 inserted 和 deleted 表。虽然在测试 INSERT 时引用 deleted 表或在测试 DELETE 时引用 inserted 表不会引起任何错误,但是在这种情形下这些触发器测试表中不会包含任何行。说明 如果触发器操作取决于一个数据修改所影响的行数,应该为多行数据修改(基于 SELECT 语句的 INSERT、DELETE 或 UPDATE)使用测试(如检查 @@ROWCOUNT),然后采取相应的对策。
SQL Server™ 2000 不允许 AFTER 触发器引用 inserted 和 deleted 表中的 text、ntext 或 image 列;然而,允许 INSTEAD OF 触发器引用这些列。有关更多信息,请参见 CREATE TRIGGER。
触发器语句中使用了两种特殊的表:deleted 表和 inserted 表。Microsoft® SQL Server™ 2000 自动创建和管理这些表。可以使用这两个临时的驻留内存的表测试某些数据修改的效果及设置触发器操作的条件;然而,不能直接对表中的数据进行更改。inserted 和 deleted 表主要用于触发器中: 扩展表间引用完整性。
在以视图为基础的基表中插入或更新数据。
检查错误并基于错误采取行动。
找到数据修改前后表状态的差异,并基于此差异采取行动。
Deleted 表用于存储 DELETE 和 UPDATE 语句所影响的行的复本。在执行 DELETE 或 UPDATE 语句时,行从触发器表中删除,并传输到 deleted 表中。Deleted 表和触发器表通常没有相同的行。Inserted 表用于存储 INSERT 和 UPDATE 语句所影响的行的副本。在一个插入或更新事务处理中,新建行被同时添加到 inserted 表和触发器表中。Inserted 表中的行是触发器表中新行的副本。更新事务类似于在删除之后执行插入;首先旧行被复制到 deleted 表中,然后新行被复制到触发器表和 inserted 表中。在设置触发器条件时,应当为引发触发器的操作恰当使用 inserted 和 deleted 表。虽然在测试 INSERT 时引用 deleted 表或在测试 DELETE 时引用 inserted 表不会引起任何错误,但是在这种情形下这些触发器测试表中不会包含任何行。