SQL Server(从 2008 开始),可以通过设置XACT_ABORT来指定当 SQL Server 语句出现运行时错误时, Transact-SQL 是否自动回滚当前事务。

XACT_ABORT

语法:

SET XACT_ABORT { ON | OFF }

  

  • 当 SET XACT_ABORT 为 ON 时,如果执行 Transact-SQL 语句产生运行时错误,则整个事务将终止并回滚。
  • 当 SET XACT_ABORT 为 OFF 时,有时只回滚产生错误的 Transact-SQL 语句,而事务将继续进行处理。 如果错误很严重,那么即使 SET XACT_ABORT 为 OFF,也可能回滚整个事务。 OFF 是默认设置。

 

编译错误(如语法错误)不受 SET XACT_ABORT 的影响。

对于大多数 OLE DB 访问接口(包括 SQL Server),必须将隐式或显示事务中的数据修改语句中的 XACT_ABORT 设置为 ON。 唯一不需要该选项的情况是在提供程序支持嵌套事务时。

当 ANSI_WARNINGS=OFF 时,违反权限的行为导致事务中止。

SET XACT_ABORT 的设置是在执行或运行时设置,而不是在分析时设置。

要查看此设置的当前设置,请运行以下查询。

DECLARE @XACT_ABORT VARCHAR(3) = 'OFF'; 
IF ( (16384 & @@OPTIONS) = 16384 ) SET @XACT_ABORT = 'ON';
SELECT @XACT_ABORT AS XACT_ABORT;

原文链接:https://docs.microsoft.com/en-us/sql/t-sql/statements/set-xact-abort-transact-sql