回滚和Raiseerror,哪个优先?

use*_*552 5 sql sql-server rollback raiseerror sql-server-2008

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

Raiseerror(...)
Rollback;
Run Code Online (Sandbox Code Playgroud)

但我想知道它是否会导致以下相同的效果:

Rollback;
Raiseerror(...)
Run Code Online (Sandbox Code Playgroud)

我了解它们是相同的,并且会产生相同的效果。首先执行回滚,执行后将继续在下一行执行,即Raiseerrror(...)

有人可以确认吗?还是最好以一种具体的方式执行这组语句?

Jam*_*sey 7

如果您在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
Run Code Online (Sandbox Code Playgroud)

  • 作为附录,因为这个答案仍然偶尔会得到赞成票:在较新的版本(我认为 2016+)中,您不需要存储错误详细信息并重新引发错误,您可以简单地使用 THROW (4认同)