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

... 61  62  [63]  64  65  66  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
1055이성환4/30/201218547WPF FramworkElement의 이벤트를 가져오고 싶습니다. [3]
1054정웅모4/20/201217304안녕하세요 [1]
1053폭풍코딩4/19/201217823스마트클라이언트 ctrl-c 복사가 작동하지 않습니다. [1]
1052에슈리온4/17/201234279ClickOnce 배포시 클라이언트의 설치경로를 지정할 수 없나요? [1]
1051최정수4/10/201221135WCF 클라이언트 비정상 종료 관련 [1]
1050에슈리온4/6/201223328관리자 권한과 ClickOnce, 그리고 Bootstrapper문제 [6]
1049김성혁4/4/201217932스마트클라이언트 stand-alone 방식의 배포 문제.. [1]
1048C#조으다3/27/201220981어셈블리 로드 / 언로드와 관련해서.. [6]
1047김우형3/23/201218795WCF 서비스를 이용한 데이터 전송 중 Exception 문의 [1]
1044임동찬2/29/201218670웹에서 COM Exception.. [2]
1043박성준2/24/201217168Lazy<T> 의 지연객체 생성 전에 실 객체의 Attribute분석 [2]파일 다운로드1
1042이성환2/20/201217507BlockingMethod에 빠진 스레드를 즉시 죽이고 싶습니다...;ㅅ; [2]파일 다운로드1
1039김재영2/15/201216955어셈블리에 사용자마다 다른 값을 적용하여 자동 빌드 방법이 있을까요? [2]
1037윈드로니2/12/201218413WPF 관련 질문 드립니다. [2]
1035임동찬2/9/201216758XML, XSD, XMLCodeGenerator 관련 [2]
1033곽성현2/7/201217296훔..윈도우 디바이스 드라이버 관련 [1]
1030궁빈2/2/201219758msbuild를 이용한 웹게시 및 자동 Dist 방법론에 대해 질문 드립니다!! [6]
1028신정환1/30/201216851기존 legacy Windows application이 WoA 환경에서 동작되지 않는 이유가 무얼까요? [2]
1026노현철1/19/201219013WPF가 XP에서 느리게 로딩되는 현상에 대해 질문드립니다. [4]
1025궁그미1/18/201220019네이버 소켓 로그인 이해가 안되는점이 있는데요 [2]
1022선무당1/11/201217981TFS 에서 공통 Assembly 공유 방법에 대해서 해결책이 없을까요? [2]
1021김재영1/8/201217110대리자를 메소드 파라메터로 넘겨도 됩니까? [2]파일 다운로드1
1019남산골11/13/201919888안녕하세요!! 성태님~~ [3]
1018강한구12/29/201123170WPF ClickOnce 배포시 콤포넌트 dll 다운로드 문제에 대하여 질문 있습니다. [1]
1017임동찬12/28/201120048smart client와 xbop, silverlight [6]
1015개똥이12/22/201117477RMCLOCK 설정 관련 질문이요ㅜ [2]
... 61  62  [63]  64  65  66  67  68  69  70  71  72  73  74  75  ...