Condividi tramite


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
ENLISTMENT_SUPERIOR
1
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

Vedere anche

CommitComplete

CommitEnlistment

funzioni di Gestione transazioni kernel

NOTIFICATION_MASK

OpenEnlistment

TRANSACTION_NOTIFICATION