• SQL Server在存储过程中编写事务处理代码的三种方法


    SQL Server中数据库事务处理是相当有用的,鉴于很多SQL初学者编写的事务处理代码存往往存在漏洞,本文我们介绍了三种不同的方法,举例说明了如何在存储过程事务处理中编写正确的代码。希望能够对您有所帮助。

    在编写SQL Server 事务相关的存储过程代码时,经常看到下面这样的写法:

    begin tran   
       update statement 1 ...   
       update statement 2 ...   
       delete statement 3 ...   
    commit tran 

    这样编写的SQL存在很大隐患。请看下面的例子:

    IF OBJECT_ID(N'demo',N'U') IS NOT NULL
    DROP TABLE demo
    create table demo(id int not null)   
    go   
    begin tran   
       insert into demo values (null)  
       insert into demo values (2)   
    commit tran   
    go 

    执行时会出现一个违反not null 约束的错误信息,但随后又提示(1 row(s) affected)。 我们执行select * from demo 
    后发现insert into demo values(2) 却执行成功了。 这是什么原因呢? 原来 SQL Server在发生runtime 
    错误时,默认会rollback引起错误的语句,而继续执行后续语句。

    如何避免这样的问题呢?

    有三种方法:

    1. 在事务语句最前面加上set xact_abort on

    set xact_abort on   
    begin tran   
       update statement 1 ...   
       update statement 2 ...   
       delete statement 3 ...   
    commit tran   
    go 

    当xact_abort 选项为on 时,SQL Server在遇到错误时会终止执行并rollback 整个事务。

    2. 在每个单独的DML语句执行后,立即判断执行状态,并做相应处理。

    begin tran   
       update statement 1 ...  
       if @@error <> 0   
          begin rollback tran   
          goto labend   
       end   
       delete statement 2 ...   
       if @@error <> 0  
          begin rollback tran   
          goto labend   
       end   
       commit tran   
       labend:   
    go 

    3. 在SQL Server 2005中,可利用 try...catch 异常处理机制。

    begin tran   
    begin try   
       update statement 1 ...   
       delete statement 2 ...   
    end try   
    begin catch  
       if @@trancount > 0   
          rollback tran   
    end catch  
       if @@trancount > 0   
          commit tran  
    go 

    关于SQL Server数据库中在存储过程中编写正确的事务处理代码的方法就介绍到这里了,希望本次的介绍能够对您有所帮助。

    原文出处:http://www.cnblogs.com/linyechengwei/archive/2011/10/09/2203898.html

  • 相关阅读:
    2015第11周日
    2015第11周六
    素数推断算法(高效率)
    vc中关于 directx的配置,和dxsdk_extras(directshow)
    几种开源分词工具的比較
    javascript实现函数的默认參数值方法
    MyReport报表引擎2.0.0.0新功能
    怎样在小方框上打对号 小方框内打对勾 word 方框打对勾
    Bombing HDU, 4022(QQ糖的消法)
    fullcalendar日历控件知识点集合
  • 原文地址:https://www.cnblogs.com/xiaozhi1236/p/5715734.html
Copyright © 2020-2023  润新知