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存在很大隐患。请看下面的例子:

    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

  • 相关阅读:
    重新认识数据库的链接查询
    mysql删除一张表中的重复数据
    mysql数据库里复制一张表的SQL,报错 (1786
    case when的使用场景。
    python:浅析python 中__name__ = '__main__' 的作用
    Group(), Groups(),& Groupdict() 用法
    python re模块findall()详解
    练习题(第二模块...模块...选择填空)
    subprocess模块 sys模块
    json,pickle,shelve模块,xml处理模块
  • 原文地址:https://www.cnblogs.com/xiaozhi1236/p/5715734.html
Copyright © 2011-2022 走看看