성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] VT sequences to "CONOUT$" vs. STD_O...
[정성태] NetCoreDbg is a managed code debugg...
[정성태] Evaluating tail call elimination in...
[정성태] What’s new in System.Text.Json in ....
[정성태] What's new in .NET 9: Cryptography ...
[정성태] 아... 제시해 주신 "https://akrzemi1.wordp...
[정성태] 다시 질문을 정리할 필요가 있을 것 같습니다. 제가 본문에...
[이승준] 완전히 잘못 짚었습니다. 댓글 지우고 싶네요. 검색을 해보...
[정성태] 우선 답글 감사합니다. ^^ 그런데, 사실 저 예제는 (g...
[이승준] 수정이 안되어서... byteArray는 BYTE* 타입입니다...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <div style='font-family: 맑은 고딕, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>ODP.NET + OraMTS 사용</div><br /> <br /> 마침, 질문을 하신 분이 있어서 TransactionScope를 이용한 트랜잭션 테스트를 마저 해보았습니다. 지난 글에서 odp.net20을 설치하는 편한 방법을 살펴봤는데요.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > .NET 응용 프로그램에서 Oracle XE 사용 ; <a target='_tab' href='/2/0/821'>http://www.sysnet.pe.kr/2/0/821</a> </pre> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > E:\...[압축해제폴더]>install.bat <b style='COLOR: blue'>odp.net20</b> E:\oracle\odpnet20 odac </pre> <br /> 위와 같이 한 경우에는 ORAMTS 구성요소가 복사되지는 않습니다. 그래서 아래와 같이 명령을 다시 추가해주면,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > E:\...[압축해제폴더]>install.bat <b style='COLOR: blue'>oramts</b> E:\oracle\odpnet20 true </pre> <br /> 다음과 같이 폴더 구성이 완료됩니다.<br /> <br /> [그림 1: ODP.NET 20과 OraMTS가 설치된 폴더 구조]<br /> <img alt='odpnet_plus_oramts_1.png' src='/SysWebRes/bbs/odpnet_plus_oramts_1.png' /><br /> <br /> 이 상태에서 해당 폴더를 PATH 환경 변수에 전역적으로 등록하든가, 아니면 <a target='_tab' href='/2/0/828'>환경 변수를 이용한 다중 ODAC 버전 테스트</a>에서 설명한 대로 응용 프로그램 상에서 PATH 환경 변수에 등록해 주면 사용이 가능합니다.<br /> <br /> 정상적으로 OraMTS가 동작하는지 다음과 같은 코드로 응용 프로그램을 실행해 보면 끝!<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > static void Main(string[] args) { SetOdpnetPath(); string oradb = "user id=hr;password=hr; data source=xeservername"; using (<b style='COLOR: blue'>TransactionScope scope = new TransactionScope()</b>) 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(); <b style='COLOR: blue'>scope.Complete();</b> } } </pre> <br /> 이 경우, MS DTC가 연동되기 때문에 코드 중간에 디버그 BP(Break Point)를 걸어두고 실행한 다음, "관리 도구" / "Component Serviices" 에서 다음과 같이 "Active" 수치가 1이 된 것을 확인할 수 있습니다.<br /> <br /> [그림 2: MS DTC 동작 상태 확인]<br /> <img alt='odpnet_plus_oramts_2.png' src='/SysWebRes/bbs/odpnet_plus_oramts_2.png' /><br /> <br /> <br /><br /><hr /><span style='color: Maroon'>[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
1225
(왼쪽의 숫자를 입력해야 합니다.)