자유롭게 질의 및 응답을 할 수 있는 게시판입니다. 개발자 여러분의 답변이 큰 도움이 됩니다. 
  • 제품설치/등록 오류 문의: 설치/등록 Q&A 이용 (제품 구매 고객 한정)

본 게시판은 개발자들이 자유롭게 질문과 답변을 공유하는 게시판입니다.
* 따라서 최대한 정중하게 질문을 올려 주세요.
* 질문을 상세히 작성해 주실 수록 좋은 답변이 올라 옵니다.
* 다른 분들도 참고할 수 있도록 결과 댓글 필수(또는 감사 댓글)
(결과 댓글을 달지 않는 경우 다음 질문에 대한 답변이 달리지 않는 불이익이 있을 수 있습니다.)
-----------------------------------------------------------------------------------------------

안녕하세요.

txt반출하는 속도가 너무 안나서 조언을 듣고자 문의드립니다.

 

DB에 있는 고객별 로우데이타를 조회화면에서 txt로 저장하는 프로그램을 만들고 있습니다.

건수가 대략 30만건되어 FDMEMTable을 이용하여 cxGrid와 연결하여 조회는 되었는데요.

cxGrid에서 직접 txt로 반출을 하면 자료가 많다보니 에러가 발생하더군요.

그래서 FDMEMTable 데이타를 직접읽어 TXT로 반출을 했는데 대략 40분정도가 소요됩니다.

40분이나 되다보니 어쩔수 없이 사용자에게 요청올때마다 쿼리로 뽑아주고 있습니다.

 

txt반출속도를 빠르게 하는 방법이 있을까요?

아래는 txt로 반출하는 샘플코드입니다.

속도개선에 대한 의견이 있으시면 주저없이 댓글해주세요

감사합니다. ^^

 

-----------------------------------------------------------------------

 

   if not CDS3.Active then
     Exit;

   try
      AssignFile(TxtF, 'C:\통계조회.txt');
      Rewrite(TxtF);
      StrData :=  '가입매장브랜드'+'|'+
                  '가입매장코드'+'|'+
                  '가입매장명'+'|'+
                  '고객번호'+'|'+
                  '문자수신여부'+'|'+
                  '발송매장브랜드'+'|'+
                  '발송매장'+'|'+
                  '발송매장명'+'|'+
                  '발송유무'+'|'+
                  '약관동의'+'|'+
                  '개인정보동의'+'|'+
                  '마케팅동의'+'|'+
                  '적립포인트'+'|'+
                  '포인트사용유무'+'|'+
                  '사용포인트'+'|'+
                  '내용';
      WriteLn(TxtF, StrData);

      i := 0;
      iNa := 0;
      with CDS3 do
      begin
         CDS3.First;
         while not eof do
         begin

           StrData := FieldByName('가입매장브랜드').AsString+'|'+
                      FieldByName('가입매장코드').AsString+'|'+
                      FieldByName('가입매장명').AsString+'|'+
                      FieldByName('고객번호').AsString+'|'+
                      FieldByName('문자수신여부').AsString+'|'+
                      FieldByName('발송매장브랜드').AsString+'|'+
                      FieldByName('발송매장').AsString+'|'+
                      FieldByName('발송매장명').AsString+'|'+
                      FieldByName('발송유무').AsString+'|'+
                      FieldByName('약관동의').AsString+'|'+
                      FieldByName('개인정보동의').AsString+'|'+
                      FieldByName('마케팅동의').AsString+'|'+
                      FieldByName('적립포인트').AsString+'|'+
                      FieldByName('포인트사용유무').AsString+'|'+
                      FieldByName('사용포인트').AsString+'|'+
                      FieldByName('내용').AsString;
           WriteLn(TxtF, StrData);
           next;
         end;
      end;

      CloseFile(TxtF);

      ShowMessage(pChar('C:통계조회.txt 로 저장되었습니다.'));
   except on E: Exception do
      begin
         ShowMessage('TXT파일이 저장되지 않았습니다.');
      end;
   end;
 

번호 제목 글쓴이 날짜 조회 수
공지 [프로그래밍 강의] 2021.6~2021.12 관리자 2015.01.22 15767
공지 유용한 관련 사이트 관리자2 2014.03.20 54580
공지 본 게시판은 개발자 여러분들의 질문과 답변을 공유하는 공간입니다. 관리자 2012.01.10 97987
3119 실행파일 크기 문제 [1] 도시니 2012.11.23 7883
3118 DBExpess 예제관련 문의 [1] ideveloper 2012.11.26 7580
3117 글을 적은지 한달이 다 되어 가는데.... Feelple(고재철) 2012.11.26 6936
3116 Excel Component 문의 [1] ideveloper 2012.11.28 7599
3115 ActionMainMenuBar를 실행중 컨트롤하는 방법 나도몰라 2012.11.30 7034
3114 Canvas 설정 문제 [1] Feelple(고재철) 2012.11.30 6751
3113 Excel 2007 제어 관련하여... [1] ideveloper 2012.11.30 10193
3112 XE3에서 FPC 와 FM 라이브러리 위치가.. [1] 푸우우 2012.12.03 10141
3111 BPL 컴파일 결과에 대한 문의입니다. CCS 2012.12.04 7544
3110 XE3 C++ builder 관련 문의 [1] 최경민 2012.12.06 8615
3109 delphi..end 에서 84페이지 29번 [2] 도도마이 2012.12.11 6699
3108 begin end 책 227페이지 문제있습니다 [2] file 도도마이 2012.12.13 6483
3107 html5 buider 문의 드립니다. secret 2012.12.14 2
3106 TPopupActionBar.AutoHotKeys [1] secret Feelple(고재철) 2012.12.24 4
3105 XE3 TMemo 버그 secret Feelple(고재철) 2013.01.01 4
3104 xe2 실행시 file 빛고을총각 2013.01.02 8836
3103 rxLib사용하기. agbnielsen 2013.01.03 9680
3102 Delphi 동영상 강의 업로드를 기다립니다. O-X 2013.01.05 7112
3101 폼과 에디터 전환문제 [2] sdj 2013.01.11 6863
3100 Begin...End 14장 datasnap예제 에러 [1] file funny 2013.01.16 7515