트랜잭션 승격
적용 대상: SQL Server
트랜잭션 승격 은 필요에 따라 완전히 배포 가능한 트랜잭션으로 자동으로 승격될 수 있는 간단한 로컬 트랜잭션을 설명합니다. 서버의 데이터베이스 트랜잭션 내에서 관리되는 저장 프로시저를 호출하면 CLR(공용 언어 런타임) 코드가 로컬 트랜잭션의 컨텍스트에서 실행됩니다. 원격 서버에 대한 연결이 데이터베이스 트랜잭션 내에서 열리면 원격 서버에 대한 연결이 분산 트랜잭션에 등록되고 로컬 트랜잭션이 분산 트랜잭션으로 자동으로 승격됩니다. 따라서 트랜잭션 승격은 필요할 때까지 분산 트랜잭션의 생성을 지연시켜 분산 트랜잭션의 오버헤드를 최소화합니다. Enlist 키워드를 사용하여 트랜잭션 승격을 사용하도록 설정한 경우 트랜잭션 승격이 자동으로 수행되며 개발자 작업이 필요하지 않습니다. .NET Framework Data Provider for SQL Server는 .NET Framework System.Data.SqlClient 네임스페이스의 클래스를 통해 처리되는 트랜잭션 승격을 지원합니다.
Enlist 키워드
ConnectionString 개체의 SqlConnection 속성은 Enlist 에서 트랜잭션 컨텍스트를 검색하고 자동으로 연결을 분산 트랜잭션에 참여시킬지 여부를 나타내는 System.Data.SqlClient 키워드를 지원합니다. 이 키워드를 true(기본값)로 설정하면 연결이 여는 스레드의 현재 트랜잭션 컨텍스트에 자동으로 등록됩니다. 이 키워드를 false로 설정하면 SqlClient 연결이 분산 트랜잭션과 상호 작용하지 않습니다. 연결 문자열에 Enlist 를 지정하지 않은 경우 연결을 열 때 해당 키워드가 검색되면 연결이 자동으로 분산 트랜잭션에 참여합니다.
분산 트랜잭션
분산 트랜잭션은 일반적으로 상당한 시스템 리소스를 사용합니다. MS DTC(Microsoft Distributed Transaction Coordinator)는 이러한 트랜잭션을 관리하고 이러한 트랜잭션에서 액세스하는 모든 리소스 관리자를 통합합니다. 반면 트랜잭션 승격은 작업을 간단한 SQL Server 트랜잭션에 효과적으로 위임하는 특별한 형태의 System.Transactions 트랜잭션입니다. System.Transactions, System.Data.SqlClient 및 SQL Server는 트랜잭션 처리와 관련된 작업을 조정하여 필요에 따라 전체 분산 트랜잭션으로 승격합니다.
트랜잭션 승격을 사용하면 활성 TransactionScope 트랜잭션을 사용하여 연결을 열고 다른 연결은 열지 않을 때 완전 분산 트랜잭션의 추가 오버헤드를 발생시키지 않고 트랜잭션이 경량 트랜잭션으로 커밋된다는 이점이 있습니다. TransactionScope에 대한 자세한 내용은 System.Transactions 사용을 참조하세요.