Microsoft MVP성태의 닷넷 이야기
.NET : 50. 공급자 독립적인 코드 작성 [링크 복사], [링크+제목 복사],
조회: 9668
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Writing Provider Independent Code in ADO.NET
; http://msdn2.microsoft.com/en-us/library/t9f29wbk.aspx

한번쯤 읽어보는 것도 좋겠지요. 아마도 여기 기술된 설계 원칙이 Enterprise Library에 반영되었을 거라 생각되는 군요.








[최초 등록일: ]
[최종 수정일: 1/24/2007]


비밀번호

댓글 작성자
 



2007-01-24 01시55분
[이방은] 글쎄 잘 모르겠네요.
저는 일단 대형 프로젝트를 해본 경험이 없어서인지..(많아야 5명 정도..ㅡ.ㅡ;;)
일단 하나의 프로젝트에서 여러 DBMS를 써본 경험도 없네요..
위 글에서 보여준 팩터리 패턴이나 엔터프라이즈템플릿에 구현되어 있는 인터페이스 형식이나(지금버전은 모르겠습니다만..예전 버전은 인터페이스로 되어있었던듯...) 써 본적이 없네요..@.@
실제로 인터페이스를 쓰거나 팩터리 패턴을 사용하는 방법은 확장성과 범용성 부분에서는 잇점이 있긴 하지만..
성능적인면은 더 떨어지지 않습니까??
3년 전쯤이지만 엔터프라이즈템플릿의 SQLHelper 의 인터페이스 구현 부분만 MSSQL 공급자 형식으로 변경 하였을경우
성능테스트에 우수함을 볼 수 있었죠..

만약에 대형 프로젝트에서 이기종간의 DBMS의 연결이 허용되어야 한다면 코딩량을 줄이기 위해서라도 위 방법이 좀 더 낫겠지만요.
이 부분도 성능으로만 본다면 각자의 공급자형식을 갖는데 더 낫겠죠..

종종 이런 얘기도 있습니다만.
예를 들어 처음에 MSSQL로 개발 되었다가 후에 ORACLE로 변경이 된다면 어떻게 할 것이냐..라고 한다면..
ㅋㅋ (대부분 이 예시를 들었던것 같습니다..ㅡ.ㅡ;)
다시 코드를 바꿔야 겠죠..@.@
그러나 이런 경우가 실제로 있다고 가정하고 약간의 퍼포먼스 손해를 감안하고 위 패턴을 사용해야 할까...하고 생각이 듭니다..

저의 경우는 그냥 MSSQL 전용..을 씁니다..

[guest]
2007-01-24 02시19분
예. 이방은 님의 말씀이 맞습니다.
그렇죠... 대표적인 비교예가... (저도 숱하게 들어봤습니다.) MSSQL 에서 Oracle 로 변경될 거면 어쩌냐 하는 것이었는데. 경험상 그러한 적이 한번도 없었습니다. 사실, 불편하게 쓰던 사람들(Oracle)이 쉬운 환경(MSSQL)으로 이전하기는 쉬워도 그 반대는 꽤나 어렵죠. 그외에도 현실적인 문제라면... 대개의 경우 프로그래머가 투입되어 작업이 되는 정도의 단계라면... ^^; 이미 개발에 사용될 것들에 대한 품위가 모두 올라간 상태이기 때문에 MSSQL 구매했다가 도중에 Oracle을 다시 구매할 정도로 용기있는 관리자가 많지는 않다는. ^^;

일단, 그건 그렇다 치고.

다시 문제로 돌아와서, 엄밀히 따지고 보면 위의 공급자 독립 코드 작성이 응용 프로그램의 성능 문제와는 그다지 연관이 없을 듯 싶습니다. 인터페이스 기반이라고 해서 성능이 늦다기 보다는. 오히려 제약이 DB 쪽의 Stored Procedure에 달려 있다고 봐도 무방하지 않을까요?

여기서는, 생각을 DB 와 함께 묶어서는 안된다고 봅니다. 대개들 "공급자 독립적인 코드 작성"을 생각하면 DB 단 까지도 독립적이어야 한다고 생각하는 것이 보통인데요. 그러다 보니, ... DB 까지도 독립적으로 만들기 위해서 SP 를 쓰지 않거나 - 쓴다 하더라도 완전히 표준 SQL쿼리만을 사용해야 하기 때문에 성능이 늦어지는 데 한몫할 수도 있을 것입니다.

그와는 달리, DB 의 SP 재활용을 어느 정도 선에서 포기하고 입력/출력만 파라미터만 설계하는 정도라면 Application 과의 독립성을 유지하는 경우가 있을 수 있겠습니다. 위에서 제시한 "공급자 독립 코드 작성"은 그런 측면에서 의미가 있다고 볼 수 있겠지요. ^^
kevin25

1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
1129정성태2/14/201114637.NET : 113. Running .NET applications in-process using AppDomains
1128정성태2/13/201115252개발 환경 구성: 143. Visual Studio 소스 서버 보안 경고창 없애기
1127정성태2/5/201114536개발 환경 구성: 142. Internet Explorer 6, 7, 8, 9 테스트 - 다중 XP Mode
1126정성태1/28/201120173개발 환경 구성: 141. 키보드 매핑을 바꾸는 레지스트리 설정파일 다운로드1
1125정성태12/24/201013512VS.NET IDE : 59. Visual Studio 2010 - 웹 프로젝트의 Web.debug.config / Web.Release.config 기능을 일반 프로젝트에 적용하는 방법
1124정성태11/16/201022222개발 환경 구성: 140. 대용량 파일 고속 전송: Rapidant
1123정성태11/11/201012179Web : 8. IE 9 플랫폼 프리뷰 6 + IE 9 베타
1122정성태11/9/201012719개발 환경 구성: 139. RemoteFX - USB Rediection
1121정성태11/6/201011652.NET : 112. The F# PowerPack, with F# Compiler Source Drops
1120정성태10/20/201013233Web : 7. Internet Explorer - Browser Mode 와 Document Mode
1119정성태10/9/201012378IIS : 32. Steps for setting up a custom identity of an IIS 6 application pool
1118정성태9/17/201011089Web : 6. Internet Explorer 9 Beta Guide for Developers
1117정성태8/25/201011570.NET : 111. Azure CDN Guide Available
1116정성태8/24/201011320Web : 5. IE 9 - UI 보더 변경에 따른 2-pixel 변화
1115정성태6/18/201013111개발 환경 구성: 138. 프로세스 덤프를 하는 다양한 방법
1114정성태6/1/201011488.NET : 110. C#5 and Meta-Programming [1]
1113정성태4/27/201012334VS.NET IDE : 58. Visual Studio 2010에 기본 내장된 WPF Tree Visualizer
1112정성태4/15/201012091개발 환경 구성: 137. How to enable remote connections in SQL Server 2008?
1111정성태4/2/201010469VS.NET IDE : 57. Simulating Peak Load with VS Load Tests
1110정성태3/30/201011415Windows 7: 4. Windows 7 / R2부터 제공되는 NT 서비스 전용 계정
1109정성태3/17/201012177개발 환경 구성: 136. SCVMM에서 VM을 Template로 만들어서 Library에 넣은 후 새로운 VM 배포하기
1107정성태3/1/201011741.NET : 109. .NET 4.0에서 obsolete로 처리되는 타입
1106정성태2/24/201012353IIS : 31. Microsoft Application Request Routing (ARR)과 TFS App Tier
1105정성태2/9/201011483Debug : 46. 프로세스 종료 시 덤프 남기는 방법
1104정성태1/26/201011639Debug : 45. Debugging References with Graph Visualizations
1103정성태11/18/200910730개발 환경 구성: 135. How to Configure WPL v1.0 SRE
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...