sql update 触发器 可获得被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表有数据(旧数据)

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

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐