微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sqlserver事务与回滚

set  XACT_ABORT  ON     -- -如果不设置该项为ON,在sql认为OFF,那么只只回滚产生错误的 Transact-sql 语句;设为ON,回滚整个事务

begin   tran  t1  -启动一个事务 update   [ water ] . dbo ErrorInf ]
set  ErrorMessage = ' test '
where  ID = 6

insert   into   ] ( ID ] ,ErrorMessage, Description ] )
Values ( 1 ,0)">test1 ' ,0)">' )

commit   tran  t1   -提交事务

复制代码

功能:实现begin tran 和commit tran之间的语句,任一如果出现错误,所有都不执

 

事务不是有错就回滚的,在不写rollback的情况下,并不是什么错误都会回滚事务,有时回滚当前语句,有时回滚整个事务

如例

tran  
into  dbo.area  values ( 1111 ' )
2222 select   1 / 0
333 commit

 

像这样,就算中间有错,也不会回滚,结果会成功添加三条记录

但有人说,比如重大错误,这事务也会所有回滚,只是我无法重现重大错误罢了

普通错误如果想回滚整个事务,只要加个set XACT_ABORT on就可以了

复制代码

on

tran

commit
但也有人写一堆@@error,如

tran  

if   @@error >   rollback

当然也行,不过写起来太麻烦了.

后来发现sql2005支持try

BEGIN  TRY
   
BEGIN   TRANSACTION
     
' )
    
0
    
' )
   
COMMIT
END  TRY
BEGIN  CATCH
   
IF   @@TRANCOUNT   >   0
     
ROLLBACK

  
DECLARE   @ErrMsg   nvarchar ( 4000 ),  @ErrSeverity   int
  
SELECT   @ErrMsg   =  ERROR_MESSAGE(),
         
@ErrSeverity   =  ERROR_SEVERITY()

  
RAISERROR ( @ErrMsg ,0)">@ErrSeverity 1 )
END  CATCH

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐