一直误解sql事务的用法.

一直误解sql事务的用法.

一直以来窃以为这样的用法是正确的.

1,begin tran....commit tran

2.set XACT_ABORT on

对于单条记录正常,但对于批插入=操作,上面的用法却错了.

正常用法为:

1,

先 set  XACT_ABORT on

再begin tran

然后commit tran

最后set  XACT_ABORT off

 

2,

先begin tran

然后插入操作,

再判断if @@error<>0  begin  rollback goto endlabel end

(对每个插入操作都要加上这句判断)

最后commit tran

endlabel:

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值