Udostępnij za pośrednictwem


OdbcTransaction Klasa

Definicja

Reprezentuje transakcję SQL, która ma zostać wykonana w źródle danych. Tej klasy nie można dziedziczyć.

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
Dziedziczenie
Dziedziczenie
OdbcTransaction
Implementuje

Przykłady

Poniższy przykład tworzy OdbcConnection i OdbcTransaction. Pokazuje również, jak używać metod BeginTransaction, Commiti 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

Uwagi

Aplikacja tworzy obiekt OdbcTransaction przez wywołanie BeginTransaction obiektu OdbcConnection. Wszystkie kolejne operacje skojarzone z transakcją (na przykład zatwierdzanie lub przerywanie transakcji) są wykonywane na obiekcie OdbcTransaction.

Właściwości

Connection

Pobiera obiekt OdbcConnection skojarzony z transakcją lub null, jeśli transakcja nie jest już prawidłowa.

DbConnection

Po zastąpieniu w klasie pochodnej pobiera obiekt DbConnection skojarzony z transakcją.

(Odziedziczone po DbTransaction)
IsolationLevel

Określa IsolationLevel dla tej transakcji.

SupportsSavepoints

Pobiera wartość wskazującą, czy to wystąpienie DbTransaction obsługuje punkty zapisywania bazy danych. Jeśli false, metody SaveAsync(String, CancellationToken), RollbackAsync(String, CancellationToken) i ReleaseAsync(String, CancellationToken), a także ich synchroniczne odpowiedniki mają zgłaszać NotSupportedException.

(Odziedziczone po DbTransaction)

Metody

Commit()

Zatwierdza transakcję bazy danych.

CommitAsync(CancellationToken)

Asynchronicznie zatwierdza transakcję bazy danych.

(Odziedziczone po DbTransaction)
CreateObjRef(Type)

Tworzy obiekt zawierający wszystkie istotne informacje wymagane do wygenerowania serwera proxy używanego do komunikowania się z obiektem zdalnym.

(Odziedziczone po MarshalByRefObject)
Dispose()

Zwalnia niezarządzane zasoby używane przez DbTransaction.

(Odziedziczone po DbTransaction)
Dispose(Boolean)

Zwalnia niezarządzane zasoby używane przez DbTransaction i opcjonalnie zwalnia zarządzane zasoby.

(Odziedziczone po DbTransaction)
DisposeAsync()

Asynchronicznie różnicuje obiekt transakcji.

(Odziedziczone po DbTransaction)
Equals(Object)

Określa, czy określony obiekt jest równy bieżącemu obiektowi.

(Odziedziczone po Object)
GetHashCode()

Służy jako domyślna funkcja skrótu.

(Odziedziczone po Object)
GetLifetimeService()
Przestarzałe.

Pobiera bieżący obiekt usługi okresu istnienia, który kontroluje zasady okresu istnienia dla tego wystąpienia.

(Odziedziczone po MarshalByRefObject)
GetType()

Pobiera Type bieżącego wystąpienia.

(Odziedziczone po Object)
InitializeLifetimeService()
Przestarzałe.

Uzyskuje obiekt usługi okresu istnienia w celu kontrolowania zasad okresu istnienia dla tego wystąpienia.

(Odziedziczone po MarshalByRefObject)
MemberwiseClone()

Tworzy płytkią kopię bieżącego Object.

(Odziedziczone po Object)
MemberwiseClone(Boolean)

Tworzy płytkią kopię bieżącego obiektu MarshalByRefObject.

(Odziedziczone po MarshalByRefObject)
Release(String)

Niszczy punkt zapisywania zdefiniowany wcześniej w bieżącej transakcji. Dzięki temu system może odzyskać niektóre zasoby przed zakończeniem transakcji.

(Odziedziczone po DbTransaction)
ReleaseAsync(String, CancellationToken)

Niszczy punkt zapisywania zdefiniowany wcześniej w bieżącej transakcji. Dzięki temu system może odzyskać niektóre zasoby przed zakończeniem transakcji.

(Odziedziczone po DbTransaction)
Rollback()

Cofa transakcję ze stanu oczekiwania.

Rollback(String)

Przywraca wszystkie polecenia, które zostały wykonane po ustanowieniu określonego punktu zapisywania.

(Odziedziczone po DbTransaction)
RollbackAsync(CancellationToken)

Asynchronicznie cofa transakcję ze stanu oczekiwania.

(Odziedziczone po DbTransaction)
RollbackAsync(String, CancellationToken)

Przywraca wszystkie polecenia, które zostały wykonane po ustanowieniu określonego punktu zapisywania.

(Odziedziczone po DbTransaction)
Save(String)

Tworzy punkt zapisu w transakcji. Dzięki temu wszystkie polecenia, które są wykonywane po ustanowieniu punktu zapisywania, mają zostać wycofane, przywracając stan transakcji do tego, co było w czasie punktu zapisu.

(Odziedziczone po DbTransaction)
SaveAsync(String, CancellationToken)

Tworzy punkt zapisu w transakcji. Dzięki temu wszystkie polecenia, które są wykonywane po ustanowieniu punktu zapisywania, mają zostać wycofane, przywracając stan transakcji do tego, co było w czasie punktu zapisu.

(Odziedziczone po DbTransaction)
ToString()

Zwraca ciąg reprezentujący bieżący obiekt.

(Odziedziczone po Object)

Jawne implementacje interfejsu

IDbTransaction.Connection

Pobiera obiekt DbConnection skojarzony z transakcją lub odwołanie o wartości null, jeśli transakcja nie jest już prawidłowa.

(Odziedziczone po DbTransaction)
IDisposable.Dispose()

Ten interfejs API obsługuje infrastrukturę produktu i nie jest przeznaczony do użycia bezpośrednio z poziomu kodu.

Zwalnia zasoby używane przez bieżące wystąpienie klasy OdbcTransaction.

Metody rozszerzania

ConfigureAwait(IAsyncDisposable, Boolean)

Konfiguruje, w jaki sposób będą wykonywane oczekiwania na zadania zwrócone z asynchronicznego jednorazowego użytku.

Dotyczy

Zobacz też