回滚和Raiseerror,这首先?

时间:2016-11-19 09:34:08

标签: sql sql-server sql-server-2008 rollback raiseerror

我有时会按以下顺序执行以下语句:

Raiseerror(...)
Rollback;

但我想知道它是否会产生与以下相同的效果:

Rollback;
Raiseerror(...)

我知道它们是相同的并且会产生相同的效果。首先执行回滚,执行后继续执行以下行,即Raiseerrror(...)

有人能证实吗?或者最好以混凝土的方式执行这组语句?

1 个答案:

答案 0 :(得分:5)

如果您处于TRY-CATCH块中会很重要 - raiserror会将执行转移到catch块,因此如果回滚在它之后(在try块内),那么它将不会执行。

此外,它还取决于错误的严重性 - 严重性20+会终止数据库连接。

一个好用的模式就像是

begin try
    begin transaction;

    -- do stuff

    commit transaction;
end try
begin catch
    declare @ErrorMessage nvarchar(max), 
        @ErrorSeverity int, 
        @ErrorState int;

    select @ErrorMessage = ERROR_MESSAGE() + ' Line ' + cast(ERROR_LINE() as nvarchar(5)), @ErrorSeverity = ERROR_SEVERITY(), @ErrorState = ERROR_STATE();

    if @@trancount > 0
        rollback transaction;

    raiserror (@ErrorMessage, @ErrorSeverity, @ErrorState);
end catch