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