Microsoft MVP성태의 닷넷 이야기
데이타셋을 레코드셋으로 변경하는 방법...... [링크 복사], [링크+제목 복사],
조회: 12574
글쓴 사람
탑 (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

[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5968orion4/30/2025223winform DataSet.xsd의 암호화 된 ConnectionString 사용 질문 [1]
5966GM B4/30/2025248C#과 python 연동 질문 [1]
5962SunN...4/21/2025553Contextmenu margin 조절 [1]파일 다운로드2
5961GM B4/10/2025947winform => wpf 마이그레이션 방법 질문 [4]파일 다운로드1
5960Kim ...4/9/20251209안녕하세요.. 혹 AI & C# 에 대해서도 다루시나요? [1]
5959vict...2/10/20251900비주얼 스투디오 CLR 코드 탑색 질문입니다. [1]
5958Supe...1/18/20252878C#으로 DLL을 만들때 WebVeiw2을 이용하여 Vb6에서 사용할수 있는지 문의드립니다. [2]
5956fc1/11/20252875한국투자증권 KIS Developers OpenAPI의 C# 래퍼 버전 - eFriendOpenAPI NuGet 패키지 [1]
5955tree...11/8/20244510C#12 책 179 페이지 문의 사항 [2]
5954SunN...10/10/20244987textbox에서 글자입력후 textBox1_KeyUp함수에서listBox1_SelectedIndexChanged 강제호출방법 [1]
5953Roya10/4/20244970c# com host dll을 c++에서 사용할 때, sdk 관련 runtime 을 설치 안하고 제공할수 있을까요?? [1]
5952우광현9/5/20246084서버용 소켓 포트 동적포트 적용시 클라이언트가 호출하는 방법? [2]
5951Kun ...8/21/20245698c++에서 복합데이터 Struct를 .NET Framework에서 구현할 수 있는 방법이 있을까요? [2]
5950SunN...8/18/20246269정석대로 한다면 response.Close() 해야되는지요? [4]
5949SunN...8/16/20246361SqlConnection Open()에서 에러가나면 Close()하는 시점 [3]
5948SunN...8/14/20246226WebRequestMethods.Ftp.MakeDirectory 해제 [3]
5947Roya8/7/20247002c# dll을 cpp lib에서 사용을 할려고 하는데요. CoCreateInstance 에서 지정된 파일을 찾을수 없다고 나오는대요. [4]
5946SunN...8/5/20247109TaskDefinition 에서 사용저가로그온상관없이실행 [3]파일 다운로드1
5945SunN...8/3/20246972윈도우 작업스케줄러 [1]
5944roya8/1/20246921C# dll을 C++ 프로젝트에서 사용을 하고 싶은데, 레지스트리 등록 없이 가능한걸까요?? [2]
5943SunN...8/1/20246804윈도우C#에서 리눅스FTP로 업로드 및 리눅스에 폴더생성(WindowsOS에서C#으로) [3]
5942vict...7/24/20246837dll 을 c#에서 쓰고 싶습니다 [1]
5941vict...7/17/20248333DependencyObject와 같은 스레드에서 DependencySource를 만들어야 합니다. 오류 [2]
5940ckm7/16/20248749선생님 안녕하세요 async await 교착 관련 질문입니다 [1]
5939괴물신인7/9/20248434템플릿 대체할수있는방법이 있을까요? [6]
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...