Microsoft MVP성태의 닷넷 이야기
데이타셋을 레코드셋으로 변경하는 방법...... [링크 복사], [링크+제목 복사],
조회: 12593
글쓴 사람
탑 (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)
5678차가워6/7/202211342원자적 실행 문의 [3]
5677장성욱6/7/202211135블루투스 포트와 시리얼포트 연결시 에러 [2]
5675차가워5/29/202212144윈도우설정 프로세스사용계획 옵션과 c# 스레드 [1]
5674민우5/29/202212444C++ 의 RTTI, Reflection 으로 객체 멤버변수, 멤버함수 목록 추출 문의 [2]
5673조은현5/25/202213072안녕하세요 선생님! c#에서 TCP/IP의 keep alive 기능의 사용법에 대해서 질문드리고 싶어요! [2]파일 다운로드2
5672game...5/23/202213146안녕하세요 GC를 일시적으로 중단시키는 방법이 있을까요? [5]
5671한예지 donator5/20/202213259델리게이트와 함수포인터 선언 시, 차이점 질문 있습니다. [3]
5670유필재5/20/202213597c#에서 현재프로그램에서 사용한 인터넷사용량 측정이 가능한가요? [3]
5669한예지 donator5/19/202211904이벤트 접근 제한자 질문 있습니다. [2]
5667ocm5/14/202211386c# 콜백 메서드 [2]
5666김호영5/13/202211734c# winform에서 svg 이미지 사용 [1]
5665장성욱5/11/202211511C# 타이머 관련 질문 [5]
5664차가워5/11/202211463아스키로 구성된 바이트를 long으로 변환 문의 [1]
5663김석규5/11/202211183VSTO를 이용해 엑셀데이터를 저장할때, 최종 입력값을 인식하지 못합니다. [2]
5662한예지 donator5/10/202210520혹시 사이트 회원가입은 어떻게 하는 것인가요? [1]
5661한예지 donator5/10/202210558for문 안에 await가 있는 경우 질문드립니다. [3]
5660tky5/10/202210729특정 작업을 멀티스레딩으로 처리 할 경우 어떤 방법이 가장 효율적일까요? [2]
5659한예지 donator5/9/202211075Task, TaskAwaiter 질문 있습니다. [3]
5658한예지 donator5/9/202212092교재 689, 690쪽(async/await) 질문입니다. [5]
5657C#초보5/8/202210908초보 단순 질문 입니다.,ㅠ [1]
5656부탁드립...5/6/20221327532bit dll 을 64bit dll 화 [2]
5655감사합니...5/5/202212681UI 스레드 관련 질문드립니다. [4]파일 다운로드1
5653고석주5/3/202211261첨부된 이미지처럼 dll 을 어떻게 추가해야 하는지 문의드립니다. [1]파일 다운로드1
5652감사합니...5/2/202210445프로그램 종료되면 리소스(관리, 비관리)는 알아서 해제 되나요? [2]
5651윤식4/26/202210895상속 구조 관련 질문드립니다. [8]
5650김기헌4/19/202210588WPF 리소스 관련 질문드립니다 [3]
1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...