SQLServer 触发器 同时插入多条记录有关问题

本文通过实例展示了在SQL Server中,由于触发器没有FOR EACH ROW选项,可能导致在同时插入或更新多条记录时出现问题。文章详细分析了错误的使用inserted和deleted表导致的不完整处理,并提供了正确的处理方式。同时,给出了一个错误示例,说明了在批量操作中如何避免数据丢失的问题。
摘要由CSDN通过智能技术生成

由于 SQL Server 的触发器, 没有 FOR EACH ROW (ORACL中有)的选项, 有时候不正确的使用 inserted 与deleted 可能会有点麻烦。

下面来一个简单的例子

--假设这个A是主表

CREATE TABLE A(
  AID INT IDENTITY(1, 1) PRIMARY KEY,
  money INT
);

-- 假设这个B是 日志表, 负责记录 A表 发生的变化。
CREATE TABLE B(
  BID INT IDENTITY(1, 1) PRIMARY KEY,

  AID INT,
  money INT
);
go

-- 假设这个C也是日志表, 负责记录 A表 发生的变化。

-- 但是这个C表是用于演示 不正确使用的例子。

CREATE TABLE C(
  CID INT IDENTITY(1, 1) PRIMARY KEY,
  AID INT,
  money INT
);
go

-- 测试的存储过程

-- 当 A 表 插入 / 更新 / 删除的时候i, 都触发。

CREATE TRIGGER AfterA
ON A
FOR INSERT,UPDATE,DELETE
AS
  DECLARE @aid INT, @money INT;
BEGIN
  IF EXISTS(SELECT 1 FROM inserted) AND NOT EXISTS(SELECT 1 FROM deleted)

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值