in-doubt xact resolution(服务器配置选项)

适用于:SQL Server

使用 in-doubt xact resolution 选项可以控制 Microsoft 分布式事务处理协调器 (MS DTC) 无法解决的默认事务结果。 事务无法解决可能与 MS DTC 停止工作或恢复时的未知事务结果有关。

下表列出了解决有疑问的事务可能出现的结果值。

结果值 说明
0 没有假设。 如果 MS DTC 无法解决任何有疑问的事务,恢复就会失败。
1 假设提交。 假设已提交任何 MS DTC 有疑问的事务。
2 假设中止。 假设已中止任何 MS DTC 有疑问的事务。

若要尽可能减少扩展的停止工作时间,管理员可以选择将此选项配置为假设提交或假设中止,如以下示例所示。

sp_configure 'show advanced options', 1  
GO  
RECONFIGURE  
GO  
sp_configure 'in-doubt xact resolution', 2 -- presume abort  
GO  
RECONFIGURE  
GO  
sp_configure 'show advanced options', 0  
GO  
RECONFIGURE  
GO  
  

另外,管理员也可能希望保留默认值(没有假设)并允许恢复失败,以便了解 DTC 故障,如以下示例所示。

sp_configure 'show advanced options', 1  
GO  
RECONFIGURE  
GO  
sp_configure 'in-doubt xact resolution', 1 -- presume commit  
GO  
reconfigure  
GO  
ALTER DATABASE pubs SET ONLINE -- run recovery again  
GO  
sp_configure 'in-doubt xact resolution', 0 -- back to no assumptions  
GO  
sp_configure 'show advanced options', 0  
GO  
RECONFIGURE  
GO  
  

in-doubt xact resolution 选项是一个高级选项。 如果使用 sp_configure 系统存储过程来更改该设置,则仅当 show advanced options 设置为 1 时才可以更改 in-doubt xact resolution 。 该设置将立即生效,无需重新启动服务器。

备注

在任何分布式事务所涉及的所有 Microsoft SQL Server 实例中,使此选项的配置始终保持一致,有助于避免数据的不一致。

另请参阅

RECONFIGURE (Transact-SQL)
服务器配置选项 (SQL Server)
sp_configure (Transact-SQL)