SQL SERVER存储过程中如何使用事务与try catch-宏鹏
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> ADP及SQL SERVER


SQL SERVER存储过程中如何使用事务与try catch

发表时间:2016/12/7 7:55:56 评论(0) 浏览(7384)  评论 | 加入收藏 | 复制
   
摘 要:SQL SERVER存储过程中如何使用事务与try catch
正 文:

 

在SQL SERVER存储过程中处理异常,我们可以利用try catch捕捉异常信息,为了保持数据的完整性,让发生异常时,能够全部回滚,需要在存储过程中使用事务,下面介绍在SQL SERVER存储过程中使用事务与try catch的方法

 

一、格式类似于

 

Create PROCEDURE YourProcedure    
AS
BEGIN
    SET NOCOUNT ON;

    BEGIN TRY---------------------开始捕捉异常
       BEGIN TRAN------------------开始事务
        Update A SET A.names = B.names FROM 表1 AS A INNER JOIN 表2 AS B ON A.id = B.id

        Update A SET A.names = B.names FROM 表1 AS A INNER JOIN 表2 AS B ON A.TEST = B.TEST

    COMMIT TRAN -------提交事务
    END TRY-----------结束捕捉异常
    BEGIN CATCH------------有异常被捕获
        IF @@TRANCOUNT > 0---------------判断有没有事务
        BEGIN
            ROLLBACK TRAN----------回滚事务
        END 
        EXEC YourLogErrorProcedure-----------记录存储过程执行时的错误信息,自定义
    END CATCH--------结束异常处理
END


 

二、捕获错误的常用函数


1、ERROR_NUMBER()  返回错误号。

2、ERROR_SEVERITY()  返回严重级别。

3、ERROR_STATE()  返回错误状态号。

4、ERROR_PROCEDURE()  返回出现错误的存储过程或触发器的名称。

5、ERROR_LINE()  返回导致错误的行号。

6、ERROR_MESSAGE()  返回错误消息的完整文本。该文本可包括任何可替换参数所提供的值,如长度、对象名或时间。

 


Access软件网交流QQ群(群号:198465573)
 
 相关文章
【Access教程】vba中调用存储过程  【漏蛧尐魚℡  2012/9/27】
SQL Server 存储过程  【杜超-2号  2013/4/13】
存储过程编写经验和优化措施  【周芳(转)  2013/9/17】
如何在ACCESS 中调用SQL 的存储过程  【闲人  2014/1/18】
微软未公开的SQLServer存储过程及有用的函数  【金宇  2015/6/2】
常见问答
技术分类
相关资源
文章搜索
关于作者

宏鹏

文章分类

文章存档

友情链接