事务嵌套常见错误分析

 数据库中执行嵌套事务时  错误:Transaction count after EXECUTE indicates that a COMMIT or ROLLBACK TRANSACTION statement is missing. Previous count = 1, current count = 0.

 

这个问题主要是因为事务的嵌套引起的。被嵌套的事务里面如果出现错误如何处理是个主要的问题。一般情况下都是用RollBack Transaction,但是这样做是不对的。
在SqlServer里,嵌套事务的层次是由@@TranCount全局变量反映出来的。每一次Begin Transaction都会引起@@TranCount加1。而每一次Commit Transaction都会使@@TranCount减1,而RollBack Transaction会回滚所有的嵌套事务包括已经提交的事务和未提交的事务,而使@@TranCount置0。

例子:

Begin Transaction -- @@TranCount = 1
BeginTransaction -- @@TranCount = 2
BeginTransaction -- @@TranCount = 3
Commit Transaction -- @@TranCount = 2
Commit Transaction -- @@TranCount = 1
Commit Transaction -- @@TranCount = 0

如果被嵌套的事务中出现错误,最简单的方法应该是无论如何都将它提交,但是应该返回错误码(如-1),从而使@@TranCount 减1 这样外层事务在回滚或者提交的时候能够保证外层事务在开始的时候和结束的时候保持一致。由于里层事务返回了错误码,因此外层事务(最外层)可以回滚事务,这样里面已经提交的事务也可以被回滚而不出现错误.


在项目中常常出现这样的情况,一个存储过程里面用了事务,但是不能保证它会被别的存储过程调用,如果单独调用的话,出现错误可以直接回滚,但是如果是被别的存储过程调用的话,RollBack 就会出错了。因此需要一种机制来区分.

 

例子:

declare @localTranCount int
set @localTranCount = 0
Begin Transaction
set @localTranCount = @localTranCount +1
…………
goto Error
Begin Transaction
set @localTranCount = @localTranCount +1
…………
goto Error
 Commit Transaction
Commit Transaction
Return 0
Error:
IF(@@TranCount = @localTranCount) RollBack Transaction
Else Commit Transaction
Return @Error

 


 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值