mysql触发器区分新增 修改_sql server 触发器实例(判断是插入、删除,还是修改)...

本文介绍了SQL Server中的触发器,通过一个具体的例子展示了如何创建一个名为`updatetest`的触发器,用于在`TEST`表上处理INSERT、UPDATE和DELETE操作。触发器利用inserted和deleted两个虚拟表来判断操作类型,并打印相应的操作信息。插入时,inserted表包含新数据;更新时,两个表都有数据;删除时,只有deleted表有数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

sql server触发器的例子。

sql代码:

代码示例:

--触发器实例

--判断是插入、删除还是修改数据

--by www.

create TRIGGER [updatetest] ON [dbo].[TEST]

FOR INSERT, UPDATE, DELETE

AS

begin

DECLARE

@IsInsert bit,

@IsUpdate bit,

@IsDelete bit

IF EXISTS(SELECT 1 FROM inserted) AND NOT EXISTS(SELECT 1 FROM deleted)

SET @IsInsert = 1

ELSE

SET @IsInsert = 0

IF EXISTS(SELECT 1 FROM inserted) AND EXISTS(SELECT 1 FROM deleted)

SET @IsUpdate = 1

ELSE

SET @IsUpdate = 0

IF NOT EXISTS(SELECT 1 FROM inserted) AND EXISTS(SELECT 1 FROM deleted)

SET @IsDelete = 1

ELSE

SET @IsDelete = 0

if (@IsUpdate=1)

PRINT 'updated '

if (@IsInsert=1)

PRINT 'insert '

if (@IsDelete=1)

PRINT 'delete '

EDN

说明:

inserted、deleted:

这是两个虚拟表,inserted 保存的是 insert 或 update 之后所影响的记录形成的表,deleted 保存的是 delete 或 update 之前所影响的记录形成的表。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值