Funzione CreateEnlistment (ktmw32.h)
Crea un'integrazione, imposta lo stato iniziale e apre un handle per l'integrazione con l'accesso specificato.
Sintassi
HANDLE CreateEnlistment(
[in, optional] LPSECURITY_ATTRIBUTES lpEnlistmentAttributes,
[in] HANDLE ResourceManagerHandle,
[in] HANDLE TransactionHandle,
[in] NOTIFICATION_MASK NotificationMask,
[in, optional] DWORD CreateOptions,
[in, optional] PVOID EnlistmentKey
);
Parametri
[in, optional] lpEnlistmentAttributes
Puntatore a una struttura SECURITY_ATTRIBUTES che contiene gli attributi di sicurezza per il gestore dell'integrazione. Specificare NULL per ottenere gli attributi predefiniti.
[in] ResourceManagerHandle
Handle per resource manager (RM) da integrare.
[in] TransactionHandle
Handle per la transazione in cui è in corso l'integrazione dell'RM.
[in] NotificationMask
Le notifiche richieste da questo RM per il parametro TransactionHandle. Per un elenco di valori validi, vedere NOTIFICATION_MASK.
[in, optional] CreateOptions
Eventuali istruzioni facoltative per l'integrazione.
Valore | Significato |
---|---|
|
Integrare come gestore delle transazioni superiore. |
[in, optional] EnlistmentKey
Puntatore a una struttura definita dall'utente utilizzata dall'RM restituita quando viene inviata una notifica nella struttura TRANSACTION_NOTIFICATION. Viene in genere usato per associare una struttura privata a questa transazione specifica.
Valore restituito
Se la funzione ha esito positivo, il valore restituito è un handle per l'integrazione.
Se la funzione ha esito negativo, il valore restituito è INVALID_HANDLE_VALUE. Per ottenere informazioni estese sull'errore, chiamare la funzione GetLastError
L'elenco seguente identifica i possibili codici di errore:
Osservazioni
Windows Vista: Qualsiasi tentativo di integrazione durante la fase di pre-preparazione o versioni successive avrà esito negativo.
Se non si specifica all'interno della maschera di notifica che si accetta una richiesta di commit a fase singola, KTM esegue sempre un'operazione di commit in due fasi.
Quando si inserisce nelle transazioni, tenere presenti le regole di notifica seguenti:
- L'RM deve sempre richiedere la notifica di rollback.
- Se l'RM richiede la notifica di preparazione, deve anche richiedere la notifica di commit.
- Se rm richiede un'operazione di commit a singola fase, deve specificare anche le notifiche di preparazione e commit.
- L'unica volta che un RM non è necessario per richiedere notifiche di commit è quando richiede almeno una coppia di notifiche di preparazione e rollback.
Fabbisogno
Requisito | Valore |
---|---|
client minimo supportato | Windows Vista |
server minimo supportato | Windows Server 2008 |
piattaforma di destinazione | Finestre |
intestazione |
ktmw32.h |
libreria |
KtmW32.lib |
dll | KtmW32.dll |