OdbcTransaction Klasa

Definicja

Reprezentuje transakcję SQL, która ma zostać wykonana w źródle danych. Klasa ta nie może być dziedziczona.

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

Przykłady

Poniższy przykład tworzy element OdbcConnection i .OdbcTransaction Pokazuje również, jak używać BeginTransactionmetod , 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 OdbcTransaction obiekt przez wywołanie BeginTransaction OdbcConnection obiektu. Wszystkie kolejne operacje skojarzone z transakcją (na przykład zatwierdzenie lub przerwanie transakcji) są wykonywane na OdbcTransaction obiekcie.

Właściwości

Connection

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

DbConnection

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

(Odziedziczone po DbTransaction)
IsolationLevel

Określa IsolationLevel dla tej transakcji.

SupportsSavepoints

Pobiera wartość wskazującą, czy to DbTransaction wystąpienie obsługuje punkty zapisywania bazy danych. Jeśli falsemetody SaveAsync(String, CancellationToken), RollbackAsync(String, CancellationToken) oraz ReleaseAsync(String, CancellationToken) ich synchroniczne odpowiedniki mają zgłaszać wartość 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 program DbTransaction.

(Odziedziczone po DbTransaction)
Dispose(Boolean)

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

(Odziedziczone po DbTransaction)
DisposeAsync()

Asynchronicznie rozprasza obiekt transakcji.

(Odziedziczone po DbTransaction)
Equals(Object)

Określa, czy dany obiekt jest taki sam, jak bieżący obiekt.

(Odziedziczone po Object)
GetHashCode()

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

(Odziedziczone po Object)
GetLifetimeService()
Nieaktualne.

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

(Odziedziczone po MarshalByRefObject)
GetType()

Type Pobiera wartość bieżącego wystąpienia.

(Odziedziczone po Object)
InitializeLifetimeService()
Nieaktualne.

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 Objectelementu .

(Odziedziczone po Object)
MemberwiseClone(Boolean)

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

(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()

Wycofywanie transakcji ze stanu oczekiwania.

Rollback(String)

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

(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 zapisu.

(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 momencie 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 momencie punktu zapisu.

(Odziedziczone po DbTransaction)
ToString()

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

(Odziedziczone po Object)

Jawne implementacje interfejsu

IDbTransaction.Connection

DbConnection Pobiera obiekt 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.

Dotyczy

Zobacz też