zoukankan      html  css  js  c++  java
  • Sql Server 事务/回滚

    复制代码
    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 [water].[dbo].[ErrorInf]([ID],ErrorMessage,[Description])
    Values(1,'test1','test1')

    commit tran t1  ---提交事务
    复制代码

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

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

    如例

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

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

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

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

    复制代码
    set XACT_ABORT on

    begin tran

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

    commit
    复制代码

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

    复制代码
    begin tran 

    insert into dbo.area values('1111')
    if @@error>0
      rollback

    insert into dbo.area values('2222')
    if @@error>0
      rollback

    select 1/0
    if @@error>0
      rollback

    insert into dbo.area values('333')
    if @@error>0
      rollback

    commit
    复制代码

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

    后来发现sql2005支持try

    复制代码
    BEGIN TRY
       
    BEGIN TRANSACTION
         
    insert into dbo.area values('1111')
        
    insert into dbo.area values('2222')
        
    select 1/0
        
    insert into dbo.area values('333')
       
    COMMIT
    END TRY
    BEGIN CATCH
       
    IF @@TRANCOUNT > 0
         
    ROLLBACK

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

      
    RAISERROR(@ErrMsg@ErrSeverity1)
    END CATCH
    复制代码
  • 相关阅读:
    快速构建ceph可视化监控系统
    Codeforces Round #277.5 解题报告
    【MapReduce】经常使用计算模型具体解释
    Unity3D教程:静态调用C#的dll
    【Oracle错误集锦】:PLSQL无法直连64位Oracle11g数据库
    关于ios下字体描边的一个细节
    未来社交站点:15秒内让你闻名全球 虚拟现实与社交网络融合
    iOS多语言(国际化)开发(尾随系统 + APP内手动设置)
    Java String对象的经典问题
    jsp+tomcat+ 创建project 配置project
  • 原文地址:https://www.cnblogs.com/linb/p/3765723.html
Copyright © 2011-2022 走看看