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

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

수고 많으십니다.

 

dbgo의 ADO query를 하기의 loop에 사용시 약 20초 이상의 시간이 걸립니다.

ADOConnection의 트랜젝션 사용시 시간을 절약할 수 있다고 들었는데 구체적인 사용법을 몰라서 문의 드립니다

 

loop를 돌려 반복하면서 ADO query를 사용하여 조건을 검색하여 테이블을 만들어 가는 기능이며 넘 시간이 걸려서  loop의 query 값을 저장해 놓았다가 한꺼번에 처리 하는것이 transaction이라고 들었습니다.

 

하기의 소스  loop를 어떻게 Transaction으로 한꺼번에 처리하여 시간을 절약흘 수 있을지 고수님의 조언 부탁드립니다

 

소스의 Loop는 최종 1520번 반복합니다.

 

제가 사용한 소스는 하기와 같습니다.

 

 

 

 Level :=  FormTestDB.ADOConnection1.BeginTrans;   // Level은 1로 표시됨.
 try
   

    중간 생략

 

       for i:= 0 to cnt-1 do       // cnt = 520
        begin

          
            ADOQuery1.SQL.Clear;
            str := 'Select * from ' + TableName + ' order by num ASC';
            ADOQuery1.SQL.Add(str);
            ADOQuery1.Active := true;

 

             for j := 1 to 3 do
             begin

                Attr_id := j;
                inc(RecordNo);

                 ADOQuery1.SQL.Clear;
         
                   str:= 'INSERT INTO ' + TableName + '(num, Obis_Code, OBIS_A, OBIS_B, OBIS_C, OBIS_D, OBIS_E, OBIS_F, Class_Id, Attribute_Id, Version_No, Descript, Data_Type, Data_Size, Data ) Values(' +
                   IntToStr(RecordNo) + ', "' + obis_code + '", ' + IntToStr(ObisA) + ', ' + IntToStr(ObisB) + ', ' + IntToStr(ObisC) + ', ' + IntToStr(ObisD) + ', '  +
                   IntToStr(ObisE) + ', ' + IntToStr(ObisF) + ', '  + IntToStr(ClassId) + ', ' + IntToStr(Attr_id) + ', ' +  IntToStr(VerNo) + ', "' + desc + '", "' +
                   strDataType + '", ' + IntToStr( DataSize ) + ', "' + strData + '" )';

 

                  ADOQuery1.SQL.Add(str);
                  ADOQuery1.ExecSQL;
          
         end;
   
      end;

 

      ADOConnection1.CommitTrans;
 except
    ON E : Exception do  ADOConnection1.RollbackTrans;
 end;

 

감사합니다.

번호 제목 글쓴이 날짜 조회 수
공지 [프로그래밍 강의] 2021.6~2021.12 관리자 2015.01.22 15767
공지 유용한 관련 사이트 관리자2 2014.03.20 54582
공지 본 게시판은 개발자 여러분들의 질문과 답변을 공유하는 공간입니다. 관리자 2012.01.10 97993
439 datasnap 세션유지 또는 재연결 [2] 델마당쇠 2020.01.14 408
438 '완료' 버튼의 키 값이 궁금합니다. [3] file 푸른솔 2020.01.14 866
437 VCL 폼스타일 변경시 TrackBar의 SelEnd 색상표시가 궁금합니다. file OJTO 2020.01.14 156
» ADO Query를 사용시 시간 걸리는 문제의 건 한태수 2020.01.14 304
435 클릭, 더블클릭 구분하는방법이 있을까요?? [1] Danny 2020.01.15 1109
434 delphi 7에서 XE 10.3.1 마이그레이션 중 PicShow 컴포너트 추가 오류 [4] file midas 2020.01.20 433
433 Form의 BorderStyle 정의시점?에 대한 차이점 질문입니다. [5] file Danny 2020.01.22 220
432 Rest Api 질문입니다. [3] 희망나라 2020.01.22 1041
431 델파이로 iso앱을 개발하려면 mac pc가 있어야 하나요? [1] 델마당쇠 2020.01.24 192
430 system.pas 에러 해결방법은 무엇인가요? [1] 날라리아 2020.01.28 2723
429 RX Currency Edit 콤포넌트를 대체할 대안이 있을까요? 날라리아 2020.01.28 205
428 안드로이드 calendar에 요일 밑에 text 추가 할수 있나요? [1] 델마당쇠 2020.01.28 1718
427 웹 상에서 이미지 다운시 질문 [4] 희망나라 2020.01.30 904
426 "Ignore this exception type" 다시 활성화 방법문의 드립니다. [1] file 슈크림 2020.01.31 749
425 원격서버(호스팅서버)에 데이터스냅 미들웨어 배포하는 방법 운직 2020.01.31 100
424 [현대화 세미나] 리눅스 환경에서 데이터스냅 배포 방법이 궁금합니다. 험프리 2020.01.31 237
423 [현대화 세미나] 윈도우, 우분투, 안드로이드, iOS, OSX 간 효과적인 마이그레이션 방법이 궁금합니다. 험프리 2020.01.31 294
422 델파이 컴파일 후 실행 오류 관련 [2] file 똘귀아빠 2020.01.31 232
421 [안드로이드][64bit배포][C++ Builder] 안드로이드 배포 관련 문의 입니다. [3] vastia 2020.02.03 357
420 스트링그리드 문자 정렬 문제 [4] file 똘귀아빠 2020.02.03 976