您的位置:首页 > 数据库 > 其它 > 正文

SQL SERVER中@@TRANCOUNT

更多 时间:2015-8-14 类别:数据库 浏览量:1991

SQL SERVER中@@TRANCOUNT

SQL SERVER中@@TRANCOUNT

一、SQL SERVER中@@TRANCOUNT的理解

在SqlServer里,嵌套事务的层次是由@@TranCount全局变量反映出来的。

每一次Begin Transaction都会引起@@TranCount加1。而每一次Commit Transaction都会使@@TranCount减1,而RollBack Transaction会回滚所有的嵌套事务包括已经提交的事务和未提交的事务,而使@@TranCount置0。

例如

  •  
  •  
  • SQL 代码   复制
  • 
     BEGIN   TRAN   --@@TRANCOUNT值为0   
          SELECT  @@TRANCOUNT         --值为1   
              BEGIN   TRAN     
                    SELECT  @@TRANCOUNT     --值为2    
              COMMIT   TRAN   
              SELECT @@TRANCOUNT   --值为1   
      ROLLBACK   TRAN   
      SELECT  @@TRANCOUNT   --值为0   
        
    
     --又如
    
      BEGIN   TRAN     --@@TRANCOUNT值为0  
          SELECT  @@TRANCOUNT         --值为1   
          SAVE   TRAN   t1   
          SELECT  @@TRANCOUNT   --值为1     
              BEGIN   TRAN     
                    SELECT  @@TRANCOUNT     --值为2   
            ROLLBACK   TRAN   t1   
              SELECT   @@TRANCOUNT   --注意这里的值为2     
      IF   @@TRANCOUNT>0   
      ROLLBACK   TRAN   
      SELECT   '处理结束',   @@TRANCOUNT   --为0
    
    		
  •  

    二、SQL SERVER中处理嵌套事务里面的错误

     

    1、在项目中应该会常常出现这样的情况,一个存储过程里面用了事务,但是不能保证它会被别的带有事务的存储过程调用,如果单独调用的话,出现错误可以直接回滚,但是如果是被别的带事务的存储过程调用的话,RollBack 就会出错了。

    2、如果被嵌套的事务中发生错误,最简单的方法应该是无论如何都先将它提交,同时返回错误码(一个正常情况不可能出现的代码 如 -1)让上一层事务来处理这个错误,从而使@@TranCount 减1。 这样外层事务在回滚或者提交的时候能够保证外层事务在开始的时候和结束的时候保持一致。由于里层事务返回了错误码,因此外层事务(最外层)可以回滚事务,这样里面已经提交的事务也可以被回滚而不会出现错误。

    3、例如

     

  •  
  • SQL 代码   复制
  • 
    DECLARE @TranCounter INT;
        SET @TranCounter = @@TRANCOUNT;
        IF @TranCounter > 0
            SAVE TRANSACTION ProcedureSave;
        ELSE
            BEGIN TRANSACTION;
    …………
    --事务内要执行的代码
    …………
     
    
    IF @@ERROR<>0
    goto Error
     Commit Transaction
    Commit Transaction
    --下面返回要返回的值0只是个例子
    Return 0 
    
    Error:
         IF @TranCounter = 0
           ROLLBACK TRANSACTION;
        Else  
    
         ROLLBACK TRANSACTION ProcedureSave;
    
       Return @Error
    
    		
  •  

    标签:SQL SERVER
    您可能感兴趣