Share via


xa_open

 

Applies To: Windows 10, Windows 7, Windows 8, Windows 8.1, Windows Server 2008, Windows Server 2008 R2, Windows Server 2012, Windows Server 2012 R2, Windows Server Technical Preview, Windows Vista

Called by the XA-based transaction manager, or any XA application that performs operations on a SQL Server database by using the XA interfaces, to initialize a Resource Manager and prepare it for use in distributed transaction processing.

Implemented by: MSDTC
Object This is a helper function, not a method on an object.
Interface Source N/A
Called by: XA-based transaction manager.

Syntax

  
int __cdecl xa_open  (  __in LPSTR xa_info,  int  rmid,  long flags);  

Parameters

xa_info
[in] The open string that contains a set of name/value pairs. In each name/value pair, the name is separated from the value by an equals sign, and each pair is separated by a comma. The name/value pairs are shown in the following table.

Name/value pair Description
TM The key that is used to determine the calling TP Monitor.
RMRecoveryGuid The key that is used to determine the Resource Manager Recovery GUID. The GUID must be specified without braces as shown in the following example. RmRecoveryGuid=b3a7647d-8ade-4816-9872-217f01b92071
Timeout The key that is used to determine the time-out value. The time-out value is specified in milliseconds. A value 0 implies no time-out and is the default value. This name/value pair is optional.
BrIso The key that is used to determine whether the XA branch is tightly coupled or loosely coupled. Loose coupling is a scheme for mapping XA Transaction Branches to atomic transactions in which each loosely coupled XA Transaction Branch is treated as operating under a different atomic transaction by the XA Subordinate Transaction Manager. Tight coupling is a scheme for mapping XA Transaction Branches to atomic transactions, in which all tightly coupled XA Transaction Branches with the same XA Global Transaction Identifier are treated as operating under one atomic transaction by the XA Subordinate Transaction Manager Facet. BrIso is an optional name/value pair. BrIso is not supported on Windows 2000 or Windows XP.

Tight: The expected open string value for branch isolation when the xa branch is tightly coupled.

The following is an example of the xa_info open string.

TM=computerName, RmRecoveryGuid=b3a7647d-8ade-4816-9872-217f01b92071, Timeout=100, BrIso=Tight  

rmid
[in] The Resource Manager ID. This uniquely identifies the Resource Manager to other xa_ function calls.

flags
[in] Flags defined in [XAOpen – DTP] Chapter 4.4.

Return Values

Return code defined in Chapter 4.5 of [XAOpen – DTP].

Remarks

The Transaction Manager must call xa_open before calling any other xa_ function, and must call xa_open on the same thread that accesses the Resource Manager.

Requirements

For an explanation of the requirement values, see Requirements (Component Services).

Platforms: Windows Server 2016, Windows 10, Windows Server 2012 R2, Windows 8.1, Windows Server 2012, Windows 8, Windows Server 2008 R2, Windows 7, Windows Server 2008, Windows Vista

Header: Declared in xa.h