事务处理嵌套的语法和对@@TRANCOUNT的影响

   
  BEGIN   TRAN     @@TRANCOUNT+1  
  COMMIT   TRAN   @@TRANCOUNT-1  
  ROLLBACK   TRAN   使@@TRANCOUNT回归0  
  SAVE   TRAN   不影响@@TRANCOUNT  
   
  举例  
  1)   SELECT   '事务处理前',   @@TRANCOUNT             --值为   0  
  BEGIN   TRAN  
      SELECT   '第一个事务',   @@TRANCOUNT         --值为   1  
          SELECT   *   FROM   table1  
          BEGIN   TRAN    
                SELECT   '第二个事务',   @@TRANCOUNT     --值为   2  
                    DELETE   table1  
          COMMIT   TRAN  
          SELECT   '递交第二个事务',   @@TRANCOUNT   --值为   1  
  ROLLBACK   TRAN  
  SELECT   '回滚第一个事务',   @@TRANCOUNT   --值为   0  
   
  2)   SELECT   '事务处理前',   @@TRANCOUNT             --值为   0  
  BEGIN   TRAN    
      SELECT   '第一个事务',   @@TRANCOUNT         --值为   1  
          SELECT   *   FROM   table1  
      SAVE   TRAN   t1  
      SELECT   '保存第一个事务后',   @@TRANCOUNT   --值为   1    
          BEGIN   TRAN    
                SELECT   '第二个事务',   @@TRANCOUNT     --值为   2  
                    DELETE   table1  
        ROLLBACK   TRAN   t1  
          SELECT   '回滚到保存点t1',   @@TRANCOUNT   --注意这里的值为   2    
  IF   @@TRANCOUNT>0  
  ROLLBACK   TRAN  
  SELECT   '处理结束',   @@TRANCOUNT   --为   0

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值