다음을 통해 공유


OracleTransaction 클래스

정의

데이터베이스에 만들 트랜잭션을 나타냅니다.

public ref class OracleTransaction sealed : MarshalByRefObject, IDisposable, System::Data::IDbTransaction
public ref class OracleTransaction sealed : System::Data::Common::DbTransaction
public sealed class OracleTransaction : MarshalByRefObject, IDisposable, System.Data.IDbTransaction
public sealed class OracleTransaction : System.Data.Common.DbTransaction
type OracleTransaction = class
    inherit MarshalByRefObject
    interface IDbTransaction
    interface IDisposable
type OracleTransaction = class
    inherit DbTransaction
Public NotInheritable Class OracleTransaction
Inherits MarshalByRefObject
Implements IDbTransaction, IDisposable
Public NotInheritable Class OracleTransaction
Inherits DbTransaction
상속
OracleTransaction
상속
구현

예제

다음 예제에서는 및 를 OracleConnectionOracleTransaction만듭니다. 사용 하는 방법을 보여 줍니다 합니다 BeginTransaction, Commit, 및 Rollback 메서드.

public void RunOracleTransaction(string connectionString)
{
    using (OracleConnection connection = new OracleConnection(connectionString))
    {
        connection.Open();

        OracleCommand command = connection.CreateCommand();
        OracleTransaction transaction;

        // Start a local transaction
        transaction = connection.BeginTransaction(IsolationLevel.ReadCommitted);
        // Assign transaction object for a pending local transaction
        command.Transaction = transaction;

        try
        {
            command.CommandText =
                "INSERT INTO Dept (DeptNo, Dname, Loc) values (50, 'TECHNOLOGY', 'DENVER')";
            command.ExecuteNonQuery();
            command.CommandText =
                "INSERT INTO Dept (DeptNo, Dname, Loc) values (60, 'ENGINEERING', 'KANSAS CITY')";
            command.ExecuteNonQuery();
            transaction.Commit();
            Console.WriteLine("Both records are written to database.");
        }
        catch (Exception e)
        {
            transaction.Rollback();
            Console.WriteLine(e.ToString());
            Console.WriteLine("Neither record was written to database.");
        }
    }
}
Public Sub RunOracleTransaction(ByVal connectionString As String)
    Using connection As New OracleConnection(connectionString)
        connection.Open()

        Dim command As OracleCommand = connection.CreateCommand()
        Dim transaction As OracleTransaction

        ' Start a local transaction
        transaction = connection.BeginTransaction(IsolationLevel.ReadCommitted)
        ' Assign transaction object for a pending local transaction
        command.Transaction = transaction

        Try
            command.CommandText = _
                "INSERT INTO Dept (DeptNo, Dname, Loc) values (50, 'TECHNOLOGY', 'DENVER')"
            command.ExecuteNonQuery()
            command.CommandText = _
                "INSERT INTO Dept (DeptNo, Dname, Loc) values (60, 'ENGINEERING', 'KANSAS CITY')"
            command.ExecuteNonQuery()
            transaction.Commit()
            Console.WriteLine("Both records are written to database.")
        Catch e As Exception
            transaction.Rollback()
            Console.WriteLine(e.ToString())
            Console.WriteLine("Neither record was written to database.")
        End Try
    End Using
End Sub

설명

애플리케이션을 만듭니다는 OracleTransaction 개체를 호출 하 여 BeginTransactionOracleConnection 개체입니다. 트랜잭션과 연결된 모든 후속 작업(예: 트랜잭션 커밋 또는 중단)은 개체에서 OracleTransaction 수행됩니다.

속성

Connection

트랜잭션과 관련된 OracleConnection 개체를 지정합니다.

DbConnection

파생 클래스에서 재정의되는 경우 트랜잭션과 연결된 DbConnection 개체를 가져옵니다.

(다음에서 상속됨 DbTransaction)
IsolationLevel

이 트랜잭션에 대한 IsolationLevel을 지정합니다.

SupportsSavepoints

DbTransaction 인스턴스가 데이터베이스 저장점을 지원하는지 여부를 나타내는 값을 가져옵니다. false인 경우 SaveAsync(String, CancellationToken), RollbackAsync(String, CancellationToken)ReleaseAsync(String, CancellationToken) 메서드와 해당 동기 메서드에서 NotSupportedException을 throw할 것으로 예상됩니다.

(다음에서 상속됨 DbTransaction)

메서드

Commit()

SQL 데이터베이스 트랜잭션을 커밋합니다.

CommitAsync(CancellationToken)

데이터베이스 트랜잭션을 비동기적으로 커밋합니다.

(다음에서 상속됨 DbTransaction)
CreateObjRef(Type)

원격 개체와 통신하는 데 사용되는 프록시 생성에 필요한 모든 관련 정보가 들어 있는 개체를 만듭니다.

(다음에서 상속됨 MarshalByRefObject)
Dispose()

이 개체에서 사용하는 리소스를 해제합니다.

Dispose()

DbTransaction에서 사용하는 관리되지 않는 리소스를 해제합니다.

(다음에서 상속됨 DbTransaction)
Dispose(Boolean)

DbTransaction에서 사용하는 관리되지 않는 리소스를 해제하고, 관리되는 리소스를 선택적으로 해제할 수 있습니다.

(다음에서 상속됨 DbTransaction)
DisposeAsync()

트랜잭션 개체를 비동기적으로 삭제합니다.

(다음에서 상속됨 DbTransaction)
Equals(Object)

지정된 개체가 현재 개체와 같은지 확인합니다.

(다음에서 상속됨 Object)
GetHashCode()

기본 해시 함수로 작동합니다.

(다음에서 상속됨 Object)
GetLifetimeService()
사용되지 않음.

이 인스턴스의 수명 정책을 제어하는 현재의 수명 서비스 개체를 검색합니다.

(다음에서 상속됨 MarshalByRefObject)
GetType()

현재 인스턴스의 Type을 가져옵니다.

(다음에서 상속됨 Object)
InitializeLifetimeService()
사용되지 않음.

이 인스턴스의 수명 정책을 제어하는 수명 서비스 개체를 가져옵니다.

(다음에서 상속됨 MarshalByRefObject)
MemberwiseClone()

현재 Object의 단순 복사본을 만듭니다.

(다음에서 상속됨 Object)
MemberwiseClone(Boolean)

현재 MarshalByRefObject 개체의 단순 복사본을 만듭니다.

(다음에서 상속됨 MarshalByRefObject)
Release(String)

현재 트랜잭션에 이전에 정의된 저장점을 제거합니다. 이렇게 하면 트랜잭션이 종료되기 전에 시스템에서 일부 리소스를 회수할 수 있습니다.

(다음에서 상속됨 DbTransaction)
ReleaseAsync(String, CancellationToken)

현재 트랜잭션에 이전에 정의된 저장점을 제거합니다. 이렇게 하면 트랜잭션이 종료되기 전에 시스템에서 일부 리소스를 회수할 수 있습니다.

(다음에서 상속됨 DbTransaction)
Rollback()

보류 상태에서 트랜잭션을 롤백합니다.

Rollback(String)

지정된 저장점이 설정된 후에 실행된 모든 명령을 롤백합니다.

(다음에서 상속됨 DbTransaction)
RollbackAsync(CancellationToken)

보류 중 상태에서 트랜잭션을 비동기적으로 롤백합니다.

(다음에서 상속됨 DbTransaction)
RollbackAsync(String, CancellationToken)

지정된 저장점이 설정된 후에 실행된 모든 명령을 롤백합니다.

(다음에서 상속됨 DbTransaction)
Save(String)

트랜잭션에 저장점을 만듭니다. 이렇게 하면 저장점이 설정된 후에 실행되는 모든 명령을 롤백하여 트랜잭션 상태를 저장점 시점의 상태로 복원할 수 있습니다.

(다음에서 상속됨 DbTransaction)
SaveAsync(String, CancellationToken)

트랜잭션에 저장점을 만듭니다. 이렇게 하면 저장점이 설정된 후에 실행되는 모든 명령을 롤백하여 트랜잭션 상태를 저장점 시점의 상태로 복원할 수 있습니다.

(다음에서 상속됨 DbTransaction)
ToString()

현재 개체를 나타내는 문자열을 반환합니다.

(다음에서 상속됨 Object)

명시적 인터페이스 구현

IDbTransaction.Connection

트랜잭션과 연결된 DbConnection 개체를 가져오거나, 트랜잭션이 더 이상 유효하지 않을 경우 null 참조를 가져옵니다.

(다음에서 상속됨 DbTransaction)

적용 대상

추가 정보