Microsoft MVP성태의 닷넷 이야기
데이타셋을 레코드셋으로 변경하는 방법...... [링크 복사], [링크+제목 복사],
조회: 12628
글쓴 사람
탑 (develtop at empal.com)
홈페이지
첨부 파일
[오류.gif]    


 데이타셋을 레코드셋으로 변경하려고 합니다.

 방법은
  
 데이타셋 -> XML -> 파일스트림 -> 레코드셋

 이렇게 하려고 하는데...

 레코드셋 -> 파일스트림 -> XML 로 변경해서 XML -> 파일스트림 -> 레코드셋
 
     Dim rs As New ADODB.Recordset
    Dim st As New ADODB.Stream
    
    st.Open
    st.WriteText txtXML.Text
    st.Position = 0
    rs.Open st

  이런 식으로 해서 XML 을 레코드셋으로 오픈을 할 수 있습니다.

 그런데

  데이타셋 -> XML -> 파일스트림 -> 레코드셋 으로 하는 방법은 안되더라구요.

  찾아보았는데....

  레코드셋 -> 파일스트림 -> XML 로 변경해서 XML -> 파일스트림 -> 레코드셋 으로 하는 방법에서
  나온 XML 파일과

  데이타셋 -> XML -> 파일스트림 -> 레코드셋
  방법에서 나온 XML 파일이 좀 다르더라구요.

 데이타셋 -> XML -> 파일스트림 -> 레코드셋 에서 나온 XML 파일은
 =========================
  <?xml version="1.0" standalone="yes" ?>
- <NewDataSet>
- <xs:schema id="NewDataSet" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
- <xs:element name="NewDataSet" msdata:IsDataSet="true" msdata:UseCurrentLocale="true">
- <xs:complexType>
- <xs:choice minOccurs="0" maxOccurs="unbounded">
- <xs:element name="TABLE1">
- <xs:complexType>
- <xs:sequence>
  <xs:element name="DEPT_CD_KIND" type="xs:string" minOccurs="0" />
  <xs:element name="DEPT_CD" type="xs:string" minOccurs="0" />
  <xs:element name="DEPT_NAME" type="xs:string" minOccurs="0" />
  <xs:element name="TREE_CD" type="xs:string" minOccurs="0" />
  <xs:element name="ORG_PART" type="xs:string" minOccurs="0" />
  <xs:element name="PRT_PRY" type="xs:string" minOccurs="0" />
  <xs:element name="MAKE_SALE" type="xs:string" minOccurs="0" />
  <xs:element name="DIR_TYPE" type="xs:string" minOccurs="0" />
  <xs:element name="USER_YN" type="xs:string" minOccurs="0" />
  <xs:element name="DIR_MAN" type="xs:decimal" minOccurs="0" />
  <xs:element name="INDIR_MAN" type="xs:decimal" minOccurs="0" />
  </xs:sequence>
  </xs:complexType>
  </xs:element>
  </xs:choice>
  </xs:complexType>
  </xs:element>
  </xs:schema>
- <TABLE1>
  <DEPT_CD_KIND>1</DEPT_CD_KIND>
  <DEPT_CD>9999</DEPT_CD>
  <DEPT_NAME>전체부서</DEPT_NAME>
  <TREE_CD>dot</TREE_CD>
  <ORG_PART>1</ORG_PART>
  <PRT_PRY>000</PRT_PRY>
  <MAKE_SALE>2</MAKE_SALE>
  <DIR_TYPE>1</DIR_TYPE>
  <USER_YN>Y</USER_YN>
  <DIR_MAN>0</DIR_MAN>
  <INDIR_MAN>0</INDIR_MAN>
  </TABLE1>
  ================================
  이런 식으로 생겼는데...
  
  레코드셋 -> 파일스트림 -> XML 로 변경해서 XML -> 파일스트림 -> 레코드셋 방법에서
   나온 XML 파일은

 ===================================
<xml xmlns:s='uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882'
    xmlns:dt='uuid:C2F41010-65B3-11d1-A29F-00AA00C14882'
    xmlns:rs='urn:schemas-microsoft-com:rowset'
    xmlns:z='#RowsetSchema'>
<s:Schema id='RowsetSchema'>
    <s:ElementType name='row' content='eltOnly'>
        <s:AttributeType name='PO_PLAN_NO' rs:number='1' rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='20'
             rs:maybenull='false'/>
        </s:AttributeType>
        <s:AttributeType name='PO_PLAN_DT' rs:number='2' rs:nullable='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='10'/>
        </s:AttributeType>
        <s:AttributeType name='EMP_NO' rs:number='3' rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='8'
             rs:maybenull='false'/>
        </s:AttributeType>
        <s:AttributeType name='NAME' rs:number='4' rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='16'
             rs:maybenull='false'/>
        </s:AttributeType>
        <s:AttributeType name='ITEM_LVL1' rs:number='5' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='3'/>
        </s:AttributeType>
        <s:AttributeType name='ITEM_LVL2' rs:number='6' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='3'/>
        </s:AttributeType>
        <s:AttributeType name='ITEM_LVL3' rs:number='7' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='3'/>
        </s:AttributeType>
        <s:AttributeType name='MODEL' rs:number='8' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='20'/>
        </s:AttributeType>
        <s:AttributeType name='MODEL_NM' rs:number='9' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='40'/>
        </s:AttributeType>
        <s:AttributeType name='PJT_NO' rs:number='10' rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='14'
             rs:maybenull='false'/>
        </s:AttributeType>
        <s:AttributeType name='ITEM_CD' rs:number='11' rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='20'
             rs:maybenull='false'/>
        </s:AttributeType>
        <s:AttributeType name='ITEM_NM' rs:number='12' rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='100'
             rs:maybenull='false'/>
        </s:AttributeType>
        <s:AttributeType name='CODE_NAME' rs:number='13' rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='50'
             rs:maybenull='false'/>
        </s:AttributeType>
        <s:AttributeType name='BASE_PRICE' rs:number='14' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='number' rs:dbtype='numeric' dt:maxLength='19'
             rs:scale='4' rs:precision='18' rs:fixedlength='true'/>
        </s:AttributeType>
        <s:AttributeType name='MONEY_UNIT' rs:number='15' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='3'/>
        </s:AttributeType>
        <s:AttributeType name='P_ITEM_CD' rs:number='16' rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='20'
             rs:maybenull='false'/>
        </s:AttributeType>
        <s:AttributeType name='SPEC' rs:number='17' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='100'/>
        </s:AttributeType>
        <s:AttributeType name='REQ_QTY' rs:number='18' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='number' rs:dbtype='numeric' dt:maxLength='19'
             rs:scale='4' rs:precision='18' rs:fixedlength='true'/>
        </s:AttributeType>
        <s:AttributeType name='PO_AMT' rs:number='19' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='number' rs:dbtype='numeric' dt:maxLength='19'
             rs:scale='4' rs:precision='18' rs:fixedlength='true'/>
        </s:AttributeType>
        <s:AttributeType name='MAKER' rs:number='20' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='30'/>
        </s:AttributeType>
        <s:AttributeType name='DVRY_DT' rs:number='21' rs:nullable='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='10'/>
        </s:AttributeType>
        <s:AttributeType name='MIN_PJT_NO' rs:number='22' rs:nullable='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='14'/>
        </s:AttributeType>
        <s:AttributeType name='MAX_PJT_NO' rs:number='23' rs:nullable='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='14'/>
        </s:AttributeType>
        <s:AttributeType name='AMT' rs:number='24'>
            <s:datatype dt:type='number' rs:dbtype='numeric' dt:maxLength='19'
             rs:scale='8' rs:precision='37' rs:fixedlength='true' rs:maybenull='false'/>
        </s:AttributeType>
        <s:AttributeType name='RMK' rs:number='25' rs:nullable='true'
             rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='200'/>
        </s:AttributeType>
        <s:AttributeType name='PO_PLAN_KIND' rs:number='26'
             rs:nullable='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='50'/>
        </s:AttributeType>
        <s:AttributeType name='BASE_ITEM_CD' rs:number='27'
             rs:nullable='true' rs:writeunknown='true'>
            <s:datatype dt:type='string' rs:dbtype='str' dt:maxLength='20'/>
        </s:AttributeType>
        <s:AttributeType name='STOCK_QTY' rs:number='28'>
            <s:datatype dt:type='number' rs:dbtype='numeric' dt:maxLength='19'
             rs:scale='4' rs:precision='38' rs:fixedlength='true' rs:maybenull='false'/>
        </s:AttributeType>
        <s:AttributeType name='old_price' rs:number='29' rs:nullable='true'>
            <s:datatype dt:type='number' rs:dbtype='numeric' dt:maxLength='19'
             rs:scale='4' rs:precision='18' rs:fixedlength='true'/>
        </s:AttributeType>
        <s:extends type='rs:rowbase'/>
    </s:ElementType>
</s:Schema>
<rs:data>
    <z:row PO_PLAN_NO='PR050700198' PO_PLAN_DT='2005-07-29'
         EMP_NO='0307022' NAME='김기환' ITEM_LVL1='*' ITEM_LVL2='*'
         ITEM_LVL3='*' MODEL='*' PJT_NO='RDNC1205001' ITEM_CD='KSP1-049229'
         ITEM_NM='PRESSURE SENSOR' CODE_NAME='EA' BASE_PRICE='.0000'
         MONEY_UNIT='KRW' P_ITEM_CD='KSP1-049229' SPEC='DP4-52(1.0MPa)'
         REQ_QTY='6.0000' PO_AMT='.0000' MAKER='SUNX' DVRY_DT='2005-07-29'
         MIN_PJT_NO='RDNC1205001' MAX_PJT_NO='RDNC1205001' AMT='.00000000'
         PO_PLAN_KIND='설계변경' BASE_ITEM_CD='*' STOCK_QTY='.0000'
         old_price='85000.0000'/>
</rs:data>
</xml>
 ===========================

이런 식으로 생겼더라구요...

  데이타셋 -> XML -> 파일스트림 -> 레코드셋 방법에서 나오는 오류가 화면과 같습니다.

 방법이 없을까요?....계속 고민 중인데....조언 좀 부탁드립니다.








[최초 등록일: ]
[최종 수정일: 5/13/2006]


비밀번호

댓글 작성자
 



2006-05-16 09시50분
죄송합니다. 이 답변은 넘어가겠습니다.
저 스스로가 ^^; 해보려는 의지가 생기지 않네요.

참고로, Dataset 의 직렬화에 대해서는 꼭 DataSet 에서 제공해 주는 방법을 쓰지 않아도 무방합니다. 물론, 그 XML 내용을 별도의 XSL 로 넘겨서 새로운 포맷의 XML 로 직렬화하는 것도 가능하겠지요. 이렇게 되면 Dataset 자체는 조절이 가능하겠고요.

레코드셋 측에서 원하는 XML 포맷을 도저히 맞춰줄 수 없다는 판단이 들면 - 사실, 맞춰줄 수 있겠지만. - 레코드셋의 load 메서드로 xml 을 한꺼번에 읽으려고 하지 마시고, 그냥 row 단위로 커스텀하게 읽어들여서 recordset 을 구성하는 것도 방법일 것입니다.

kevin25
2006-05-17 02시19분
답변 감사드립니다.
develtop

... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5487진우4/27/202113389C# 엑셀 자동화 성능 향상 문의 [2]
5486지나가던...4/26/202113186닷넷 구현 코드 관련 질문 [2]
5485이재원4/17/202113382교재 315페이지 내용 질문 [3]
5484Syong4/16/202117328윈폼 기반의 응용프로그램 dll 참조와 32,64bit 빌드 관련 문의 [4]
5483한예지 donator4/15/202112357익명 형식과 var 관계 질문 있습니다. [2]
5482질문4/13/202114304WPF를 위한 MVVM toolkit 선택과 관련한 문의드립니다. [4]
5480한예지 donator4/5/202115225GetHashCode 질문있습니다! [2]
5479한예지 donator4/4/202114067Equals를 닷넷에서 어떻게 구현했는지 보고 싶을 떄는 어떻게 해야 될까요? [2]
5478갑자기C#3/23/202117049C# Winform에서 TextBox없이 입력 받을 수 있나요? [7]
5477달팽이3/18/202113218c# 도형을 그린후 편집하는 방법이 궁금합니다. [2]파일 다운로드1
5475dimo...3/2/202114104POH가 .NET 5에 추가된 것으로 알고 있습니다. POH가 유용한 경우는 어떤 경우가 있을까요? [1]
5474Syong2/26/202113630사용자 지정 컨트롤 생성시 Invalidate, Update, Refresh의 차이점 [2]
5473한예지 donator2/25/202113062디자인 타임이 뭔지 궁금합니다!! [5]
5472dimo...2/24/202114523등록하지 않고 ocx를 사용하는 `키움`관련 포스팅을 따라가다 질문드립니다. [9]
5471남산2/21/202112959MarshalDirectiveException 에 대한 질문입니다. [1]
5470한예지 donator2/7/202112697yield 질문있습니다!! [2]
5469유호성2/6/202112559Parallel + Task.Run 동시 실행 환경에서 간헐적으로 Task.Run()에서 null이 리턴됩니다. [3]파일 다운로드1
5467hero...2/4/202113125실행 환경에 따른 Thread.Sleep 딜레이 차이 질문 [8]
5466pr1/29/202112979c# winform load시 작업표시줄에 뜨지 않는 현상을 겪으신적이 있으신가요? [4]파일 다운로드1
5465영귤1/28/202113141두 번째 await 부터는 스레드 개수만 늘어나는 것이 아닌가요 [1]
5464민우1/26/202113975C# 빌드시 코드 치환되는걸 확인하는 방법 문의 [2]
5463한예지 donator1/24/202114698Parameters.AddWithValue 와 Parameters.Add 의 차이점이 궁금합니다. [2]
5462C#초보1/22/202114817사용자 정의 메시지 전달이 가능한가요? [2]
5461한예지 donator1/22/202113848AsEnumerable() 메서드 질문 있습니다! [2]
5459한예지 donator1/21/202113155typeof와 GetType의 차이점 질문있습니다. [2]
5458진우1/20/202114343C# DataTable 에 SQL 쿼리문을 실행하는 방법 문의 (LINQ 사용하지 않고) [6]
... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...