加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql-server – 回滚嵌套事务的内部事务

发布时间:2020-12-12 16:31:54 所属栏目:MsSql教程 来源:网络整理
导读:假设我在sql server 2008中有以下sql语句: BEGIN TRANSACTION SqlStatement1 EXEC sp1 SqlStatement3COMMIT TRANSACTION sp1的代码 BEGIN TRANSACTIONSqlStatement2ROLLBACK TRANSACTION 我的问题是:SqlStatement3是否实际执行? 解决方法 您可以使用 trans
假设我在sql server 2008中有以下sql语句:
BEGIN TRANSACTION    
SqlStatement1    
EXEC sp1    
SqlStatement3
COMMIT TRANSACTION

sp1的代码

BEGIN TRANSACTION
SqlStatement2
ROLLBACK TRANSACTION

我的问题是:SqlStatement3是否实际执行?

解决方法

您可以使用 transaction savepoints. sp1可以使用像 Error Handling and Nested Transactions中描述的模式:
create procedure [usp_my_procedure_name]
as
begin
    set nocount on;
    declare @trancount int;
    set @trancount = @@trancount;
    begin try
        if @trancount = 0
            begin transaction
        else
            save transaction usp_my_procedure_name;

        -- Do the actual work here

lbexit:
        if @trancount = 0   
            commit;
    end try
    begin catch
        declare @error int,@message varchar(4000),@xstate int;
        select @error = ERROR_NUMBER(),@message = ERROR_MESSAGE(),@xstate = XACT_STATE();
        if @xstate = -1
            rollback;
        if @xstate = 1 and @trancount = 0
            rollback
        if @xstate = 1 and @trancount > 0
            rollback transaction usp_my_procedure_name;

        raiserror ('usp_my_procedure_name: %d: %s',16,1,@error,@message) ;
    end catch   
end

这样的模式允许在sp1中完成的工作回滚,但是保持包含的事务处于活动状态.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读