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 un Transaction instance, EnlistTransaction tire parti des fonctionnalités disponibles dans l’espace System.Transactions de noms pour la 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 au niveau de la source de données sont également validées ou restaurées.

EnlistDistributedTransactionretourne une exception si a déjà démarré une transaction à l’aide BeginTransactionde SqlConnection . 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 à

Voir aussi