欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

sql update 触发器 可获得被update的行的信息

程序员文章站 2024-02-11 18:11:16
复制代码 代码如下: create trigger tgname on tb for update as if update(recommend) begin update...
复制代码 代码如下:

create trigger tgname
on tb
for update
as
if update(recommend)
begin
update tb set commenddate=(getdate()) from tb inner join inserted on tb.vlistid=inserted.vlistid
end

recommend表示被更新的字段.
关键在于inserted表
触发器语句中使用了两种特殊的表:deleted 表和 inserted 表。
deleted 表用于存储 delete 和 update 语句所影响的行的复本。在执行 delete 或 update 语句时,行从触发器表中删除,并传输到 deleted 表中。deleted 表和触发器表通常没有相同的行。

inserted 表用于存储 insert 和 update 语句所影响的行的副本。在一个插入或更新事务处理中,新建行被同时添加到 inserted 表和触发器表中。inserted 表中的行是触发器表中新行的副本。

1.插入操作(insert)
inserted表有数据,deleted表无数据

2.删除操作(delete)
inserted表无数据,deleted表有数据

3.更新操作(update)
inserted表有数据(新数据),deleted表有数据(旧数据)

生前何必久睡,死后自会长眠!