Partager via


OdbcTransaction Classe

Définition

Représente une transaction SQL à effectuer à une source de données. Cette classe ne peut pas être héritée.

public ref class OdbcTransaction sealed : System::Data::Common::DbTransaction
public ref class OdbcTransaction sealed : MarshalByRefObject, IDisposable, System::Data::IDbTransaction
public sealed class OdbcTransaction : System.Data.Common.DbTransaction
public sealed class OdbcTransaction : MarshalByRefObject, IDisposable, System.Data.IDbTransaction
type OdbcTransaction = class
    inherit DbTransaction
type OdbcTransaction = class
    inherit MarshalByRefObject
    interface IDbTransaction
    interface IDisposable
Public NotInheritable Class OdbcTransaction
Inherits DbTransaction
Public NotInheritable Class OdbcTransaction
Inherits MarshalByRefObject
Implements IDbTransaction, IDisposable
Héritage
Héritage
OdbcTransaction
Implémente

Exemples

L’exemple suivant crée un OdbcConnection et un OdbcTransaction. Il montre également comment utiliser les méthodes BeginTransaction, Commitet Rollback.

public static void ExecuteTransaction(string connectionString)
{
    using (OdbcConnection connection =
               new OdbcConnection(connectionString))
    {
        OdbcCommand command = new OdbcCommand();
        OdbcTransaction transaction = null;

        // Set the Connection to the new OdbcConnection.
        command.Connection = connection;

        // Open the connection and execute the transaction.
        try
        {
            connection.Open();

            // Start a local transaction
            transaction = connection.BeginTransaction();

            // Assign transaction object for a pending local transaction.
            command.Connection = connection;
            command.Transaction = transaction;

            // Execute the commands.
            command.CommandText =
                "Insert into Region (RegionID, RegionDescription) VALUES (100, 'Description')";
            command.ExecuteNonQuery();
            command.CommandText =
                "Insert into Region (RegionID, RegionDescription) VALUES (101, 'Description')";
            command.ExecuteNonQuery();

            // Commit the transaction.
            transaction.Commit();
            Console.WriteLine("Both records are written to database.");
        }
        catch (Exception ex)
        {
            Console.WriteLine(ex.Message);
            try
            {
                // Attempt to roll back the transaction.
                transaction.Rollback();
            }
            catch
            {
                // Do nothing here; transaction is not active.
            }
        }
        // The connection is automatically closed when the
        // code exits the using block.
    }
Public Sub ExecuteTransaction(ByVal connectionString As String)

    Using connection As New OdbcConnection(connectionString)
        Dim command As New OdbcCommand()
        Dim transaction As OdbcTransaction

        ' Set the Connection to the new OdbcConnection.
        command.Connection = connection

        ' Open the connection and execute the transaction.
        Try
            connection.Open()

            ' Start a local transaction.
            transaction = connection.BeginTransaction()

            ' Assign transaction object for a pending local transaction.
            command.Connection = connection
            command.Transaction = transaction

            ' Execute the commands.
            command.CommandText = _
                "Insert into Region (RegionID, RegionDescription) VALUES (100, 'Description')"
            command.ExecuteNonQuery()
            command.CommandText = _
                "Insert into Region (RegionID, RegionDescription) VALUES (101, 'Description')"
            command.ExecuteNonQuery()

            ' Commit the transaction.
            transaction.Commit()
            Console.WriteLine("Both records are written to database.")

        Catch ex As Exception
            Console.WriteLine(ex.Message)
            ' Try to rollback the transaction
            Try
                transaction.Rollback()

            Catch
                ' Do nothing here; transaction is not active.
            End Try
        End Try
        ' The connection is automatically closed when the
        ' code exits the Using block.
    End Using
End Sub

Remarques

L’application crée un objet OdbcTransaction en appelant BeginTransaction sur l’objet OdbcConnection. Toutes les opérations suivantes associées à la transaction (par exemple, la validation ou l’abandon de la transaction) sont effectuées sur l’objet OdbcTransaction.

Propriétés

Connection

Obtient l’objet OdbcConnection associé à la transaction, ou null si la transaction n’est plus valide.

DbConnection

En cas de substitution dans une classe dérivée, obtient l’objet DbConnection associé à la transaction.

(Hérité de DbTransaction)
IsolationLevel

Spécifie la IsolationLevel de cette transaction.

SupportsSavepoints

Obtient une valeur qui indique si cette instance DbTransaction prend en charge les points d’enregistrement de base de données. Si false, les méthodes SaveAsync(String, CancellationToken), les RollbackAsync(String, CancellationToken) et les ReleaseAsync(String, CancellationToken) ainsi que leurs équivalents synchrones sont censés lever NotSupportedException.

(Hérité de DbTransaction)

Méthodes

Commit()

Valide la transaction de base de données.

CommitAsync(CancellationToken)

Valide de façon asynchrone la transaction de base de données.

(Hérité de DbTransaction)
CreateObjRef(Type)

Crée un objet qui contient toutes les informations pertinentes requises pour générer un proxy utilisé pour communiquer avec un objet distant.

(Hérité de MarshalByRefObject)
Dispose()

Libère les ressources non managées utilisées par le DbTransaction.

(Hérité de DbTransaction)
Dispose(Boolean)

Libère les ressources non managées utilisées par le DbTransaction et libère éventuellement les ressources managées.

(Hérité de DbTransaction)
DisposeAsync()

Dipose de façon asynchrone l’objet transactionnel.

(Hérité de DbTransaction)
Equals(Object)

Détermine si l’objet spécifié est égal à l’objet actuel.

(Hérité de Object)
GetHashCode()

Sert de fonction de hachage par défaut.

(Hérité de Object)
GetLifetimeService()
Obsolète.

Récupère l’objet de service de durée de vie actuel qui contrôle la stratégie de durée de vie de cette instance.

(Hérité de MarshalByRefObject)
GetType()

Obtient la Type de l’instance actuelle.

(Hérité de Object)
InitializeLifetimeService()
Obsolète.

Obtient un objet de service de durée de vie pour contrôler la stratégie de durée de vie de cette instance.

(Hérité de MarshalByRefObject)
MemberwiseClone()

Crée une copie superficielle du Objectactuel.

(Hérité de Object)
MemberwiseClone(Boolean)

Crée une copie superficielle de l’objet MarshalByRefObject actuel.

(Hérité de MarshalByRefObject)
Release(String)

Détruit un point d’enregistrement précédemment défini dans la transaction actuelle. Cela permet au système de récupérer certaines ressources avant la fin de la transaction.

(Hérité de DbTransaction)
ReleaseAsync(String, CancellationToken)

Détruit un point d’enregistrement précédemment défini dans la transaction actuelle. Cela permet au système de récupérer certaines ressources avant la fin de la transaction.

(Hérité de DbTransaction)
Rollback()

Restaure une transaction à partir d’un état en attente.

Rollback(String)

Restaure toutes les commandes qui ont été exécutées après l’établissement du point de sauvegarde spécifié.

(Hérité de DbTransaction)
RollbackAsync(CancellationToken)

Restaure de façon asynchrone une transaction à partir d’un état en attente.

(Hérité de DbTransaction)
RollbackAsync(String, CancellationToken)

Restaure toutes les commandes qui ont été exécutées après l’établissement du point de sauvegarde spécifié.

(Hérité de DbTransaction)
Save(String)

Crée un point d’enregistrement dans la transaction. Cela permet à toutes les commandes exécutées après l’établissement du point d’enregistrement d’être restaurées, en restaurant l’état de la transaction sur ce qu’il était au moment de l’enregistrement.

(Hérité de DbTransaction)
SaveAsync(String, CancellationToken)

Crée un point d’enregistrement dans la transaction. Cela permet à toutes les commandes exécutées après l’établissement du point d’enregistrement d’être restaurées, en restaurant l’état de la transaction sur ce qu’il était au moment de l’enregistrement.

(Hérité de DbTransaction)
ToString()

Retourne une chaîne qui représente l’objet actuel.

(Hérité de Object)

Implémentations d’interfaces explicites

IDbTransaction.Connection

Obtient l’objet DbConnection associé à la transaction ou une référence Null si la transaction n’est plus valide.

(Hérité de DbTransaction)
IDisposable.Dispose()

Cette API prend en charge l'infrastructure du produit et n'est pas destinée à être utilisée directement à partir de votre code.

Libère les ressources utilisées par l’instance actuelle de la classe OdbcTransaction.

Méthodes d’extension

ConfigureAwait(IAsyncDisposable, Boolean)

Configure la façon dont les attentes sur les tâches retournées à partir d’un jetable asynchrone sont effectuées.

S’applique à

Voir aussi