EXECUTE 后的事务计数指示缺少了 COMMIT 或 ROLLBACK TRANSACTION 语句。上一计数 = 1,当前计数 = 2...

理解这一句话:

一个begin tran会增加一个事务计数器,要有相同数量的commit与之对应,而rollback可以回滚全部计数器

 

这个错误一般是出现在嵌套事务中.

测试环境 sql 2008

例如:

begin transaction t1

--这里是逻辑处理

 begin transaction t2
  --建立一个事务点
  save transaction point2
  --这里是逻辑处理
  --这里报错了,需要回滚事务
if @@error<>0
  begin
    goto roll2
  end
  
  roll2
  begin
    rollback transaction point2
  end
  commit transaction t2
  
commit transaction t1
-------------------------------------------------------------------------
需要注意:

事务t2里面报错后,如果直接使用rollback transaction 进行回滚操作,会同时消除t1 和 t2 的计数器 而导致出现上述错误。
如果只是 回滚到指定点point2,不提交事务t2,将会导致begin tran  和 commit 不对应,也会出现上述错误。
所以 
事务t2里面报错后,先回滚到指定点point2 ,再将事务t2 提交了。
 
 

 

转载于:https://www.cnblogs.com/xiaonanmu/p/4988925.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值