티스토리 뷰

프로그래밍/ASP.NET

트랜잭션 수행

메모하는습관 2010.01.07 14:53

ADO.NET의 트랜잭션은 여러 작업을 바인딩하여 하나의 작업 단위로 실행하려는 경우에 사용합니다. 예를 들어, 응용 프로그램에서 두 작업을 수행한다고 가정합니다. 먼저 응용 프로그램에서 주문 정보로 테이블을 업데이트합니다. 두 번째 응용 프로그램은 재고 정보가 포함된 테이블을 업데이트하고 주문이 들어온 품목을 차변에 기입합니다. 두 작업 중 하나라도 실패하면 두 업데이트가 모두 롤백됩니다.

트랜잭션 유형 결정

트랜잭션이 단일 단계 트랜잭션이고 데이터베이스에서 직접 처리되는 경우 로컬 트랜잭션으로 간주됩니다. 트랜잭션이 트랜잭션 모니터로 조정되고 트랜잭션 확인에 2단계 커밋 같은 오류 없이 안전한 메커니즘을 사용할 경우 분산 트랜잭션으로 간주됩니다.

각 .NET Framework 데이터 공급자에는 로컬 트랜잭션을 수행하기 위한 고유한 Transaction 개체가 있습니다. SQL Server 데이터베이스에서 트랜잭션을 수행해야 하는 경우 System.Data.SqlClient 트랜잭션을 선택합니다. Oracle 트랜잭션의 경우System.Data.OracleClient 공급자를 사용합니다. 트랜잭션이 필요한 공급자 독립적인 코드를 작성하는 데 사용할 수 있는 새로운 DbTransaction 클래스도 있습니다.

Note참고

트랜잭션은 서버에서 수행하는 것이 가장 효율적입니다. 명시적 트랜잭션을 폭넓게 사용하는 SQL Server 데이터베이스를 사용하는 경우 Transact-SQL BEGIN TRANSACTION 문을 사용하여 트랜잭션을 저장 프로시저로 작성하는 것이 좋습니다. 서버측 트랜잭션 수행에 대한 자세한 내용은 SQL Server 온라인 설명서를 참조하십시오.

단일 연결을 사용하여 트랜잭션 수행

ADO.NET에서는 Connection 개체로 트랜잭션을 제어합니다. BeginTransaction 메서드를 사용하면 로컬 트랜잭션을 시작할 수 있습니다. 트랜잭션이 시작되면 Command 개체의 Transaction 속성을 사용하여 해당 트랜잭션에 명령을 등록할 수 있습니다. 그런 다음 트랜잭션 구성 요소의 성공 또는 실패에 따라 데이터 소스에서 수정된 내용을 커밋 또는 롤백할 수 있습니다.

Note참고

EnlistDistributedTransaction 메서드는 로컬 트랜잭션에 사용할 수 없습니다.

트랜잭션의 범위는 연결로 제한됩니다. 다음 예제에서는 try 블록에서 두 개의 개별 명령으로 이루어진 명시적 트랜잭션을 수행합니다. 두 명령은 AdventureWorks SQL Server 2005 샘플 데이터베이스에서 Production.ScrapReason 테이블에 대해 INSERT 문을 실행합니다. 이 작업은 예외가 발생하지 않을 경우 커밋됩니다. catch 블록의 코드는 예외가 발생하는 경우 트랜잭션을 롤백합니다. 트랜잭션이 완료되기 전에 트랜잭션이 중단되거나 연결이 끊어지면 트랜잭션이 자동으로 롤백됩니다.

다음 단계를 사용하여 트랜잭션을 수행합니다.

프로시저

트랜잭션을 수행하려면

  1. SqlConnection 개체의 BeginTransaction 메서드를 호출하여 트랜잭션의 시작을 표시합니다. BeginTransaction 메서드는 트랜잭션에 대한 참조를 반환합니다. 이 참조는 트랜잭션에 참여한 SqlCommand 개체에 할당됩니다.

  2. Transaction 개체를 실행할 SqlCommand의 Transaction 속성에 할당합니다. Transaction 개체를 Command 개체의 Transaction 속성에 할당하지 않은 상태에서 활성 트랜잭션 연결로 명령을 실행하면 예외가 발생합니다.

  3. 명령을 실행합니다.

  4. SqlTransaction 개체의 Commit 메서드를 호출하여 트랜잭션을 완료하거나 Rollback 메서드를 호출하여 트랜잭션을 중단합니다. Commit 또는 Rollback 메서드가 실행되기 전에 연결이 닫히거나 삭제되면 트랜잭션이 롤백됩니다.

다음 코드 예제에서는 Microsoft SQL Server와 ADO.NET을 사용하여 트랜잭션 논리를 설명합니다.

Visual Basic
Using connection As SqlConnection = New SqlConnection(connectString)
    connection.Open()

    ' Start a local transaction.
    Dim sqlTran As SqlTransaction = connection.BeginTransaction()

    ' Enlist the command in the current transaction.
    Dim command As SqlCommand = connection.CreateCommand()
    command.Transaction = sqlTran

    Try
        command.CommandText = _
          "INSERT INTO Production.ScrapReason(Name) VALUES('Wrong size')"
        command.ExecuteNonQuery()
        command.CommandText = _
          "INSERT INTO Production.ScrapReason(Name) VALUES('Wrong color')"
        command.ExecuteNonQuery()
        sqlTran.Commit()
        Console.WriteLine("Both records were written to database.")
    Catch ex As Exception
        Console.WriteLine(ex.Message)
        Console.WriteLine("Neither record was written to database.")
        sqlTran.Rollback()
    End Try
End Using
C#
using (SqlConnection connection = new SqlConnection(connectString))
{
    connection.Open();

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

    // Enlist the command in the current transaction.
    SqlCommand command = connection.CreateCommand();
    command.Transaction = sqlTran;

    try
    {
        command.CommandText =
          "INSERT INTO Production.ScrapReason(Name) VALUES('Wrong size')";
        command.ExecuteNonQuery();
        command.CommandText =
          "INSERT INTO Production.ScrapReason(Name) VALUES('Wrong color')";
        command.ExecuteNonQuery();
        sqlTran.Commit();
        Console.WriteLine("Both records were written to database.");
    }
    catch (Exception ex)
    {
        Console.WriteLine(ex.Message);
        Console.WriteLine("Neither record was written to database.");
        sqlTran.Rollback();
    }
}

출처 : MSDN

'프로그래밍 > ASP.NET' 카테고리의 다른 글

파일 수신 제한  (0) 2010.01.27
connection pool  (0) 2010.01.07
연결 풀링 이해  (0) 2010.01.07
트랜잭션 수행  (0) 2010.01.07
연결 풀링 사용  (0) 2010.01.07
보호되는 구성을 사용하여 구성 정보 암호화  (0) 2010.01.07
댓글
댓글쓰기 폼