Partager via


SqlConnection.EnlistDistributedTransaction(ITransaction) Méthode

Définition

S’inscrit dans la transaction spécifiée en tant que transaction distribuée.

public:
 void EnlistDistributedTransaction(System::EnterpriseServices::ITransaction ^ transaction);
public void EnlistDistributedTransaction (System.EnterpriseServices.ITransaction transaction);
member this.EnlistDistributedTransaction : System.EnterpriseServices.ITransaction -> unit
Public Sub EnlistDistributedTransaction (transaction As ITransaction)

Paramètres

transaction
ITransaction

Référence à un ITransaction existant dans lequel s’inscrire.

Remarques

Vous pouvez utiliser la EnlistTransaction méthode pour inscrire dans une transaction distribuée. Étant donné qu’il inscrit une connexion dans une Transaction instance, EnlistTransaction tire parti des fonctionnalités disponibles dans l’espace de noms pour la System.Transactions gestion des transactions distribuées, ce qui le rend préférable à EnlistDistributedTransaction à cet effet. Pour plus d’informations, consultez Transactions distribuées.

Vous pouvez continuer à inscrire dans une transaction distribuée existante à l’aide de la méthode EnlistDistributedTransaction si l’inscription automatique est désactivée. L’inscription dans une transaction distribuée existante garantit que, si la transaction est validée ou restaurée, les modifications apportées par le code à la source de données sont également validées ou restaurées.

EnlistDistributedTransaction retourne une exception si a déjà démarré une transaction à l’aide de SqlConnectionBeginTransaction. Toutefois, si la transaction est une transaction locale démarrée à la source de données (par exemple, en exécutant explicitement l’instruction BEGIN TRANSACTION à l’aide d’un SqlCommand objet), EnlistDistributedTransaction annule la transaction locale et s’inscrit dans la transaction distribuée existante comme demandé. Vous ne recevez pas de notification indiquant que la transaction locale a été restaurée et que vous êtes responsable de la gestion des transactions locales qui n’ont pas démarré à l’aide de BeginTransaction.

S’applique à