mysql xact abort_XACT_ABORT 用法

首先创建一张表

Create Table TranTable

(

Id INT IDENTITY(1,1) PRIMARY KEY,

Priority TINYINT--最大值255

)

1.再执行下面的语句:

set XACT_ABORT ON

begin tran

INSERT INTO TranTable  VALUES(1)

INSERT INTO TranTable VALUES(256)

INSERT INTO TranTable  VALUES(5)

commit tran

出现下面的message:

(1 row(s) affected)

Msg 220, Level 16, State 2, Line 4

Arithmetic overflow error for data type tinyint, value = 256.

有一条语句出错整个事务回滚,没有问题

2.当我们设置 set XACT_ABORT OFF

执行后出现下面的Message

(1 row(s) affected)

Msg 220, Level 16, State 2, Line 4 Arithmetic overflow error for data type tinyint, value = 256. The statement has been terminated.

(1 row(s) affected)

每条语句都是各自为事务,没有整个事务回滚

这时候就需要通过捕获异常,回滚事务

Message 信息:

(1 row(s) affected)

(0 row(s) affected)

整个事务回滚

3.执行下面的脚本,注意没有 begin tran

set XACT_ABORT ON

go

begin

INSERT INTO TranTable  VALUES(1)

INSERT INTO TranTable VALUES(256)

INSERT INTO TranTable  VALUES(5)

end

Message 信息:

(1 row(s) affected)

Msg 220, Level 16, State 2, Line 4

Arithmetic overflow error for data type tinyint, value = 256.

每个语句作为一个事务,事务在错误行终止,错误行回滚,错误行之前的不回滚

PS:

新建一个连接,执行下面的脚本:

INSERT INTO TranTable  VALUES(1)

INSERT INTO TranTable VALUES(256)

INSERT INTO TranTable  VALUES(5)

发现有插进了两条数据

如果执行下面的脚本

INSERT INTO TranTable  VALUES(1)

select ff from TranTable -- 没有ff这一列

INSERT INTO TranTable  VALUES(5)

会发现三条语句作为一个事务,整体回滚

也许就应了这句话的解释:在事务中,回滚一个语句还是整个事务视错误的严重程序而定,用户级错误一般不会回滚整个事务

set XACT_ABORT OFF 为默认设置,是否回滚整个事务也是要看错误的级别

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值