Microsoft MVP성태의 닷넷 이야기
.NET Framework: 95. WCF에서의 DataTable 사용 [링크 복사], [링크+제목 복사],
조회: 26075
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 



WCF에서의 DataTable 사용


우선, 다음의 토픽을 읽어보십시오.

[WCF]데이터 보내기1
; http://blog.naver.com/unbimanse?Redirect=Log&logNo=30008913599

예전에 소개해 드렸던, "BUG: 웹 서비스에서 DataTable 사용하기"에서는 ASMX 웹 서비스에서 어떻게 DataTable을 사용하는지에 대해서 설명했는데, 이런 방식도 WCF에서는 통하지 않는다는 내용을 담고 있습니다.

자... 이제 세월이 또 지났군요. ^^
어느새 VS.NET 2008이 나왔고, 서비스 프록시 클래스를 생성할 때, 참조된 어셈블리에 있는 데이터 타입을 활용하도록 svcutil.exe가 개선이 되었습니다. (엄밀히, 이 기능은 VS.NET 2008에서 개선되었다기보다는 "svcutil.exe" 프로그램이 개선되었다고 봐야죠. Microsoft SDK 6.0A 버전에는 개선된 기능을 담고 있는 svcutil.exe가 포함되어 있습니다.)

그럼... DataTable에 대한 지원이, 좀 나아졌을까요?

확인을 위해서 기왕 테스트 하는 김에 TypedDataset / Untyped Dataset과 함께 DataTable을 함께 다뤄봤습니다.

일단, "Untyped"인 경우에는 부가적인 작업이 필요 없지만, TypedDataset을 테스트하기 위해서 다음과 같이 "DataSet1.xsd"를 만들었습니다.

vsnet2008_wcf_support_datatable_1.png

그리고 다음과 같은 간단한 DataTable 구성 함수를 만들고,

private DataTable GetTestDataTable()
{
  DataTable table = new DataTable();
  table.Columns.Add("CustomerID", typeof(string));
  table.Columns.Add("Age", typeof(int));

  DataRow row = table.NewRow();
  row["CustomerID"] = "myName";
  row["Age"] = 16;

  table.Rows.Add(row);

  return table;
}

private TestLib.DataSet1.TableRootDataTable GetTestCustomDataTable()
{
  TestLib.DataSet1.TableRootDataTable table = new TestLib.DataSet1.TableRootDataTable();

  TestLib.DataSet1.TableRootRow row = table.NewTableRootRow();
  row.CustomerID = "Customer001";
  table.Rows.Add(row);

  return table;
}

위의 함수를 이용해서 다음과 같이 간단한 Operation을 구성했습니다. (ServiceContract 인터페이스는 생략)

[OperationBehavior]
public DataSet GetDataSet()
{
  DataSet ds = new DataSet("TestTable");
  ds.Tables.Add(GetTestDataTable());
  return ds;
}

[OperationBehavior]
public DataTable GetDataTable()
{
  return GetTestDataTable();
}

[OperationBehavior]
public DataSet1 GetCustomDataSet()
{
  DataSet1 ds = new DataSet1();
  ds.TableRoot.Merge(GetTestCustomDataTable());
  return ds;
}

[OperationBehavior]
public TestLib.DataSet1.TableRootDataTable GetCustomDataTable()
{
  return GetTestCustomDataTable();
}

이제 서비스를 시작하고, 클라이언트 측에서 "서비스 참조"를 해봅니다. 우선, 궁금한 것은 Operation에 대한 함수 Signature가 어떻게 되었는지인데요. 오호... 훌륭하게 다음과 같이 생성되어 있습니다.

=== Reference.cs ===
public System.Data.DataTable GetDataTable() {
    return base.Channel.GetDataTable();
}

public System.Data.DataSet GetDataSet() {
    return base.Channel.GetDataSet();
}

public TestLib.DataSet1 GetCustomDataSet() {
    return base.Channel.GetCustomDataSet();
}

public TestLib.DataSet1.TableRootDataTable GetCustomDataTable() {
    return base.Channel.GetCustomDataTable();
}

짐작하시겠지만, 이렇게 코드가 생성된 데에는 "Reuse types in referenced assemblies"의 힘이 큽니다. ^^




정말 값들이 제대로 들어가 있는지 클라이언트에서도 확인을 해볼까요?

간단하게, 테이블 데이터 출력 함수를 아래와 같이 만들고,

private void OutputDataTable(DataTable dt)
{
  Debug.WriteLine("=== Table Name : " + dt.TableName + " ==== "); 
  foreach (DataRow row in dt.Rows)
  {
    Debug.WriteLine(row.Field("CustomerID"));
  }
}

private void OutputDataSet(DataSet ds)
{
  foreach (DataTable dt in ds.Tables)
  {
    OutputDataTable(dt);
  }
}

서비스 함수 호출을 다음과 같이 했습니다.

DataSet ds = svc.GetDataSet();
OutputDataSet(ds);

DataTable dt = svc.GetDataTable();
OutputDataTable(dt);

DataSet1 cds = svc.GetCustomDataSet();
OutputDataSet(cds);

TestLib.DataSet1.TableRootDataTable cdt = svc.GetCustomDataTable();
OutputDataTable(cdt);

결과는... 어찌되었을까요? ^^ 두말할 것도 없이 잘 나왔겠지요.

Debug Output 실행 결과:

=== Table Name : TestTable ==== 
myName
=== Table Name : TestTable ==== 
myName
=== Table Name : TableRoot ==== 
Customer001
=== Table Name : TableRoot ==== 
Customer001





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







[최초 등록일: ]
[최종 수정일: 4/10/2022]

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

비밀번호

댓글 작성자
 




... 151  152  153  154  155  156  [157]  158  159  160  161  162  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1121정성태9/12/201127581Java: 5. WTP 내에서 서블릿을 실행하는 환경
1120정성태9/11/201127509.NET Framework: 239. IHttpHandler.IsReusable 속성 이야기파일 다운로드1
1119정성태9/11/201126625Java: 4. 이클립스에 WTP SDK가 설치되지 않는다면? [2]
1118정성태9/11/201138276Java: 3. 이클립스에서 서블릿 디버깅하는 방법 [4]
1117정성태9/9/201125563제니퍼 .NET: 17. 제니퍼 닷넷 적용 사례 (2) - 웹 애플리케이션 hang의 원인을 알려주다.
1116정성태9/8/201156640Java: 2. 자바에서 "Microsoft SQL Server JDBC Driver" 사용하는 방법
1115정성태9/4/201130125Java: 1. 닷넷 개발자가 처음 실습해 본 서블릿
1114정성태9/4/201134645Math: 2. "Zhang Suen 알고리즘(세선화, Thinning/Skeletonization)"의 C# 버전 [4]파일 다운로드1
1113정성태9/2/201134209개발 환경 구성: 129. Hyper-V에 CentOS 설치하기
1112정성태9/2/201150951Linux: 1. 리눅스 <-> 윈도우 원격 접속 프로그램 사용 [3]
1111정성태8/29/201125415제니퍼 .NET: 16. 적용 사례 (1) - DB Connection Pooling을 사용하지 않았을 때의 성능 저하를 알려주다. [1]
1110정성태8/26/201126741오류 유형: 136. RDP 접속이 불연속적으로 끊기는 문제
1109정성태8/26/201129617오류 유형: 135. 어느 순간 Active Directory 접속이 안되는 문제
1108정성태8/22/201131172오류 유형: 134. OLE/COM Object Viewer - DllRegisterServer in IVIEWERS.DLL failed. [1]
1107정성태8/21/201128913디버깅 기술: 43. Windows Form의 Load 이벤트에서 발생하는 예외가 Visual Studio에서 잡히지 않는 문제
1106정성태8/20/201127244웹: 26. FailedRequestTracing 설정으로 인한 iisexpress.exe 비정상 종료 문제
1105정성태8/19/201127168.NET Framework: 238. Web Site Model 프로젝트에서 Trace.WriteLine 출력이 dbgview.exe에서 확인이 안 되는 문제파일 다운로드1
1104정성태8/19/201127316웹: 25. WebDev보다 IIS Express가 더 나은 점 - 다중 가상 디렉터리 매핑 [1]
1103정성태8/19/201133203오류 유형: 133. WCF 포트 바인딩 실패 오류 - TCP error(10013) [1]
1102정성태8/19/201130963Math: 1. 방탈출3 - Room 10의 '중복가능한 조합' 문제를 위한 C# 프로그래밍 [2]파일 다운로드1
1101정성태8/19/201129642.NET Framework: 237. WCF AJAX 서비스와 JavaScript 간의 DateTime 연동 [1]파일 다운로드1
1100정성태8/17/201128760.NET Framework: 236. SqlDbType - DateTime, DateTime2, DateTimeOffset의 차이점파일 다운로드1
1099정성태8/15/201128164오류 유형: 132. 어느 순간 갑자기 접속이 안 되는 TFS 서버
1098정성태8/15/201150180웹: 24. 네이버는 어떻게 로그인 처리를 할까요? [2]
1097정성태8/15/201121498.NET Framework: 235. 메서드의 메타 데이터 토큰 값으로 클래스를 찾아내는 방법
1096정성태8/15/201125654디버깅 기술: 42. Watson Bucket 정보를 이용한 CLR 응용 프로그램 예외 분석 - (2)
... 151  152  153  154  155  156  [157]  158  159  160  161  162  163  164  165  ...