Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 68. ODP.NET + OraMTS 사용 [링크 복사], [링크+제목 복사],
조회: 24128
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 6개 있습니다.)
개발 환경 구성: 63. ODP.NET 설치 없이 .NET 클라이언트 프로그램 배포하는 방법
; https://www.sysnet.pe.kr/2/0/822

개발 환경 구성: 64. ODP.NET 설치 작업 없이 ASP.NET 응용 프로그램 배포
; https://www.sysnet.pe.kr/2/0/823

개발 환경 구성: 65. .NET 응용 프로그램에서 64비트 Oracle Data Access Components 사용
; https://www.sysnet.pe.kr/2/0/825

개발 환경 구성: 66. .NET 응용 프로그램에서 64비트 Oracle Data Access Components 사용 (2)
; https://www.sysnet.pe.kr/2/0/827

개발 환경 구성: 67. 환경 변수를 이용한 다중 ODAC 버전 테스트
; https://www.sysnet.pe.kr/2/0/828

개발 환경 구성: 68. ODP.NET + OraMTS 사용
; https://www.sysnet.pe.kr/2/0/829




ODP.NET + OraMTS 사용


마침, 질문을 하신 분이 있어서 TransactionScope를 이용한 트랜잭션 테스트를 마저 해보았습니다. 지난 글에서 odp.net20을 설치하는 편한 방법을 살펴봤는데요.

.NET 응용 프로그램에서 Oracle XE 사용
; https://www.sysnet.pe.kr/2/0/821

E:\...[압축해제폴더]>install.bat odp.net20 E:\oracle\odpnet20 odac

위와 같이 한 경우에는 ORAMTS 구성요소가 복사되지는 않습니다. 그래서 아래와 같이 명령을 다시 추가해주면,

E:\...[압축해제폴더]>install.bat oramts E:\oracle\odpnet20 true

다음과 같이 폴더 구성이 완료됩니다.

[그림 1: ODP.NET 20과 OraMTS가 설치된 폴더 구조]
odpnet_plus_oramts_1.png

이 상태에서 해당 폴더를 PATH 환경 변수에 전역적으로 등록하든가, 아니면 환경 변수를 이용한 다중 ODAC 버전 테스트에서 설명한 대로 응용 프로그램 상에서 PATH 환경 변수에 등록해 주면 사용이 가능합니다.

정상적으로 OraMTS가 동작하는지 다음과 같은 코드로 응용 프로그램을 실행해 보면 끝!

static void Main(string[] args)
{
    SetOdpnetPath();

    string oradb = "user id=hr;password=hr; data source=xeservername";

    using (TransactionScope scope = new TransactionScope())
    using (OracleConnection conn = new OracleConnection(oradb))
    {
        conn.Open();

        Random random = new Random((int)DateTime.Now.Ticks);
        int regionId = random.Next(Int32.MaxValue);

        OracleCommand command = new OracleCommand();
        command.Connection = conn;
        command.Parameters.Add(new OracleParameter("REGION_ID", regionId));
        command.Parameters.Add(new OracleParameter("REGION_NAME", "test"));
        command.CommandText = "INSERT INTO Regions(REGION_ID, REGION_NAME) VALUES(:REGION_ID, :REGION_NAME)";
        command.ExecuteNonQuery();

        command = new OracleCommand();
        command.Connection = conn;
        command.Parameters.Clear();
        command.Parameters.Add(new OracleParameter("REGION_ID", regionId));
        command.CommandText = "DELETE FROM Regions WHERE REGION_ID = :REGION_ID";
        command.ExecuteNonQuery();

		scope.Complete();
    }
}

이 경우, MS DTC가 연동되기 때문에 코드 중간에 디버그 BP(Break Point)를 걸어두고 실행한 다음, "관리 도구" / "Component Serviices" 에서 다음과 같이 "Active" 수치가 1이 된 것을 확인할 수 있습니다.

[그림 2: MS DTC 동작 상태 확인]
odpnet_plus_oramts_2.png




[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 6/10/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11844정성태3/14/201924521개발 환경 구성: 434. Visual Studio 2019 - 리눅스 프로젝트를 이용한 공유/실행(so/out) 프로그램 개발 환경 설정 [1]파일 다운로드1
11843정성태3/14/201919347기타: 75. MSDN 웹 사이트를 기본으로 영문 페이지로 열고 싶다면?
11842정성태3/13/201917209개발 환경 구성: 433. 마이크로소프트의 CoreCLR 프로파일러 예제를 Visual Studio CMake로 빌드하는 방법 [1]파일 다운로드1
11841정성태3/13/201917665VS.NET IDE: 132. Visual Studio 2019 - CMake의 컴파일러를 기본 g++에서 clang++로 변경
11840정성태3/13/201919731오류 유형: 526. 윈도우 10 Ubuntu App 환경에서는 USB 외장 하드 접근 불가
11839정성태3/12/201923747디버깅 기술: 124. .NET Core 웹 앱을 호스팅하는 Azure App Services의 프로세스 메모리 덤프 및 windbg 분석 개요 [3]
11838정성태3/7/201927491.NET Framework: 811. (번역글) .NET Internals Cookbook Part 1 - Exceptions, filters and corrupted processes [1]파일 다운로드1
11837정성태3/6/201941167기타: 74. 도서: 시작하세요! C# 7.3 프로그래밍 [10]
11836정성태3/5/201924826오류 유형: 525. Visual Studio 2019 Preview 4/RC - C# 8.0 Missing compiler required member 'System.Range..ctor' [1]
11835정성태3/5/201922971.NET Framework: 810. C# 8.0의 Index/Range 연산자를 .NET Framework에서 사용하는 방법 및 비동기 스트림의 컴파일 방법 [3]파일 다운로드1
11834정성태3/4/201921647개발 환경 구성: 432. Visual Studio 없이 최신 C# (8.0) 컴파일러를 사용하는 방법
11833정성태3/4/201922711개발 환경 구성: 431. Visual Studio 2019 - CMake를 이용한 공유/실행(so/out) 리눅스 프로젝트 설정파일 다운로드1
11832정성태3/4/201917723오류 유형: 524. Visual Studio CMake - rsync: connection unexpectedly closed
11831정성태3/4/201918503오류 유형: 523. Visual Studio 2019 - 새 창으로 뜬 윈도우를 닫을 때 비정상 종료
11830정성태2/26/201917744오류 유형: 522. 이벤트 로그 - Error opening event log file State. Log will not be processed. Return code from OpenEventLog is 87.
11829정성태2/26/201919044개발 환경 구성: 430. 마이크로소프트의 CoreCLR 프로파일러 예제 빌드 방법 - 리눅스 환경 [1]
11828정성태2/26/201927456개발 환경 구성: 429. Component Services 관리자의 RuntimeBroker 설정이 2개 있는 경우 [8]
11827정성태2/26/201919919오류 유형: 521. Visual Studio - Could not start the 'rsync' command on the remote host, please install it using your system package manager.
11826정성태2/26/201920454오류 유형: 520. 우분투에 .NET Core SDK 설치 시 패키지 의존성 오류
11825정성태2/25/201926123개발 환경 구성: 428. Visual Studio 2019 - CMake를 이용한 리눅스 빌드 환경 설정 [1]
11824정성태2/25/201920401오류 유형: 519. The SNMP Service encountered an error while accessing the registry key SYSTEM\CurrentControlSet\Services\SNMP\Parameters\TrapConfiguration. [1]
11823정성태2/21/201921381오류 유형: 518. IIS 관리 콘솔이 뜨지 않는 문제
11822정성태2/20/201920538오류 유형: 517. docker에 설치한 MongoDB 서버로 연결이 안 되는 경우
11821정성태2/20/201921303오류 유형: 516. Visual Studio 2019 - This extension uses deprecated APIs and is at risk of not functioning in a future VS update. [1]
11820정성태2/20/201924442오류 유형: 515. 윈도우 10 1809 업데이트 후 "User Profiles Service" 1534 경고 발생
11819정성태2/20/201923496Windows: 158. 컴퓨터와 사용자의 SID(security identifier) 확인 방법
... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...