Microsoft MVP성태의 닷넷 이야기
.NET Framework: 39. DataSet 방식을 RecordSet으로 구현하는 방법. [링크 복사], [링크+제목 복사],
조회: 23451
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 


특히, 웹 서비스에서 DataSet을 반환하는 방식을 많이 쓰지요.
엄밀히 따지고 보면, 이미 그러한 방식은 이전의 ADODB에서도 사용할 수 있었습니다.
단지, ^^ 그 당시에는 특별히 일반화되어 씌여질 만큼 유명하지 않았을 뿐인데요.

다음의 코드를 봐두는 것도 좋을 듯 싶습니다.


------------------ ADO28.aspx ------------------------
  private void Page_Load(object sender, System.EventArgs e)
  {
   ADODB.Connection cn = new ADODB.ConnectionClass();
   cn.ConnectionString = "provider=sqloledb;server=localhost;database=TestDB;uid=XXXXX;password=XXXXX;";

   cn.Open( null, null, null, 0);

   ADODB.Recordset rs = new ADODB.RecordsetClass();
   rs.CursorLocation = ADODB.CursorLocationEnum.adUseClient;
   rs.CursorType = ADODB.CursorTypeEnum.adOpenStatic;
   rs.LockType = ADODB.LockTypeEnum.adLockBatchOptimistic;

   rs.Open( "SELECT * FROM testTable", cn, ADODB.CursorTypeEnum.adOpenStatic, ADODB.LockTypeEnum.adLockBatchOptimistic, 0 );

   rs.ActiveConnection = null;
   cn.Close();

   MSXML2.DOMDocument40Class xmlDoc = new MSXML2.DOMDocument40Class();
   rs.Save( xmlDoc, ADODB.PersistFormatEnum.adPersistXML );
   rs.Close();

   Response.Clear();

   Response.ContentType = "text/xml";
   Response.Charset = "utf-8";
   Response.Write( xmlDoc.xml );
   Response.End();
  }


그리고는,,, 받는 측에서도 역시 RecordSet으로 그대로 받으면 되겠지요. 다음과 같은 코드가 일반적일 것입니다.

------------ ADOConsume.asp --------------------
<%@Language=JScript%>
<%

var adoRec = new ActiveXObject( "ADODB.Recordset" );

adoRec.Open( "http://localhost/Test/ADO28.aspx", "Provider=MSPersist;", 0, 1, 256 );

%>











[최초 등록일: ]
[최종 수정일: 7/28/2021]

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

비밀번호

댓글 작성자
 




... 136  [137]  138  139  140  141  142  143  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1722정성태7/25/201424875오류 유형: 232. IIS 500 Internal Server Error - NTFS 암호화된 폴더에 웹 애플리케이션이 위치한 경우
1721정성태7/24/201428648.NET Framework: 451. 함수형 프로그래밍 개념 - 리스트 해석(List Comprehension)과 순수 함수 [2]
1720정성태7/23/201425754개발 환경 구성: 232. C:\WINDOWS\system32\LogFiles\HTTPERR 폴더에 로그 파일을 남기지 않는 설정
1719정성태7/22/201430166Math: 13. 동전을 여러 더미로 나누는 경우의 수 세기(Partition Number) - 두 번째 이야기파일 다운로드1
1718정성태7/19/201439818Math: 12. HTML에서 수학 관련 기호/수식을 표현하기 위한 방법 - MathJax.js [4]
1716정성태7/17/201439765개발 환경 구성: 231. PC 용 무료 안드로이드 에뮬레이터 - genymotion
1715정성태7/13/201433774기타: 47. 운영체제 종료 후에도 USB 외장 하드의 전원이 꺼지지 않는 경우 [3]
1714정성태7/11/201423580VS.NET IDE: 92. Visual Studio 2013을 지원하는 IL Support 확장 도구
1713정성태7/11/201447445Windows: 98. 윈도우 시스템 디스크 용량 확보를 위한 "Package Cache" 폴더 이동 [1]
1712정성태7/10/201436373.NET Framework: 450. 영문 윈도우에서 C# 콘솔 프로그램의 유니코드 출력 방법 [3]
1711정성태7/10/201440869Windows: 97. cmd.exe 창에서 사용할 폰트를 추가하는 방법 [1]
1710정성태7/8/201433802개발 환경 구성: 230. 유니코드의 Surrogate Pair, Supplementary Characters가 뭘까요?파일 다운로드2
1709정성태7/8/201430278VS.NET IDE: 91. Visual Studio에서 32/64비트 IIS Express 실행하는 방법
1708정성태7/7/201427579VS.NET IDE: 90. Visual Studio - 사용자 정의 정적 분석 규칙 만드는 방법 [3]파일 다운로드1
1707정성태7/4/201425803.NET Framework: 449. C#에서 C++로 VARIANT 넘겨주는 방법파일 다운로드1
1706정성태7/3/201423951.NET Framework: 448. .NET SmartClient 컨트롤을 윈도우 8/2012에서 활성화하는 방법파일 다운로드1
1705정성태7/2/201439248VC++: 78. 보이어-무어(Boyer-Moore) 알고리즘이 정말 빠를까? [6]파일 다운로드1
1704정성태7/2/201425282.NET Framework: 447. w3wp.exe AppPool 재생(recycle)하는 방법 정리
1703정성태7/2/201426412.NET Framework: 446. Assembly.Load를 이용해 GAC에 등록된 어셈블리를 로드하는 방법 [1]파일 다운로드1
1702정성태6/23/201426308Phone: 11. Xamarin.Forms - 2. XAML을 이용한 페이지 개발파일 다운로드1
1701정성태6/23/201438749개발 환경 구성: 229. .NET Reflector + Reflexil 도구를 이용해 DLL 코드 변경 [4]
1700정성태6/23/201425250VS.NET IDE: 89. Visual Studio에서 기본 제공되는 성능 프로파일 [2]
1699정성태6/22/201426570Phone: 10. Xamarin.Forms - 1. Forms 시작하기 [2]파일 다운로드1
1698정성태6/22/201428608.NET Framework: 445. [부연 설명] 쉬운 C# 코드를 어럽게 이해하기 [2]
1697정성태6/22/201424540VS.NET IDE: 88. Visual Studio에서 직접 컴파일하는 IL 언어 확장 도구 - IL Support
1696정성태6/22/201423796.NET Framework: 444. clojure와 C#을 통해 이해하는 Sequence와 Vector 형식의 차이점 [1]
... 136  [137]  138  139  140  141  142  143  144  145  146  147  148  149  150  ...