zoukankan      html  css  js  c++  java
  • SQL Server在存储过程中编写事务处理代码的三种方法

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

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

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

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

    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.sqlstudy.com/sql_article.php?id=2008060701

  • 相关阅读:
    core.net 创建coreclass 项目出现一些问题
    【BZOJ4144】[AMPPZ2014]Petrol 最短路+离线+最小生成树
    【BZOJ4774/4006】修路/[JLOI2015]管道连接 斯坦纳树
    【BZOJ2595】[Wc2008]游览计划 斯坦纳树
    【BZOJ4149】[AMPPZ2014]Global Warming 单调栈+RMQ+二分
    【BZOJ4764】弹飞大爷 LCT
    【BZOJ3529】[Sdoi2014]数表 莫比乌斯反演+树状数组
    【BZOJ5008】方师傅的房子 三角剖分
    【BZOJ4282】慎二的随机数列 乱搞
    【BZOJ1568】[JSOI2008]Blue Mary开公司 线段树
  • 原文地址:https://www.cnblogs.com/linyechengwei/p/2203898.html
Copyright © 2011-2022 走看看