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

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

안녕하세요

또 질문 드리게 됐습니다...

XE5 사용중 이구요....

ADOConnection

ADOQuery

DataSource

위 3개는 DataModule에 있고

사용 으로 메인폼에 DBgrid 로 보여지고 서브폼은 ShowModal로 띄우고  여기에 있는 데이타를 쿼리문을 만들어 메인폼에 보내고 메인폼에서 

 

  DBModule.ADOQuery.Close;

  DBModule.ADOQuery.SQL.Clear;

  DBModule.ADOQuery.SQL.Text := Value;

  DBModule.ADOQuery.ExecSQL;

 

실행 하고.... DBGrid 내용을 Refresh 하기 위하여 

 

  DBModule.ADOQuery.Close;

  DBModule.ADOQuery.SQL.Clear;

  DBModule.ADOQuery.SQL.Text := 'SELECT * FROM Table';

  DBModule.ADOQuery.Open;

 

했습니다. 

한번은 잘 되는데 여러번 실행 하면 Access violation 에러가 납니다...

 

문제는 쿼리문을 함수에서 받지 않고 내부에서 직접 작성하여

DBModule.ADOQuery.SQL.Text := 'INSERT INTO Table (  ) Values (   )'; 하고

 refresh 실행 하면 잘 작동 하는데...

 

쿼리문을 서브폼에서 받아서 실행 하면 refresh 쪽에서 에러가 나는 것 같은데 정확하게 모르겠습니다...

' Access violation at address 0040564B in Module 'Project3.exe'. Read of address 00000000. ' 요렇게 뜨는데....

제 생각은 refresh 할 때 에러가 나는 것 같습니다.. Refresh 하기 위해 찾아 보니...

Dataset.refresh, Query.refresh 여러가지가 있는거 같습니다. 

따라 해보면 Cannot perform this operation on a closed dataset.

이렇게 뜨네요

이것땜에 또 몇일 보내내요....에휴....지나가다 보시면 정보좀 부탁드립니다.

감사합니다...

 

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

계속 하다보니 문제는 서브폼이 모달 폼으로 띄워져서 종료 할때 문제가 발생하는 것 같습니다...

메인폼에서

    fmAdd := TfmAdd.Create(Nil);

    fmAdd.ShowModal;

이렇게 띄우고 종료 할때 서브폼에서 쿼리문 보내주고 

    ModalResult := mrOk;

이렇게 되어 있습니다.

서브폼 Close에서는

  Action := caFree;

  fmAdd := nil;

이렇게 해놨는데....

무슨 문제가 있나용?

 

 

 

 

번호 제목 글쓴이 날짜 조회 수
공지 [프로그래밍 강의] 2021.6~2021.12 관리자 2015.01.22 15766
공지 유용한 관련 사이트 관리자2 2014.03.20 54580
공지 본 게시판은 개발자 여러분들의 질문과 답변을 공유하는 공간입니다. 관리자 2012.01.10 97983
699 NFC 관련 앱을 XE 시리즈로 개발 가능한지요? [1] 유탐호호 2014.09.02 1317
698 MDI, CHILD 구성 DLL Form Close [1] 가나다 2021.01.11 1317
697 [세미나] VCL 말고 웹(PHP) 등에서도 푸시 보낼 수 있나요? [1] Humphery 2014.08.20 1322
696 (공유) 웹페이지에서 실행파일(*.exe) 다운로드 시 경고가 발생합니다. 험프리 2020.04.10 1342
695 [세미나] BaaS에서 아이디와 이메일 중복확인 기능을 제공하나요? [1] Humphery 2014.08.05 1346
694 [XE5] XE5에선 GCM 사용이 불가능한가요? [1] 와니 2014.10.17 1347
693 안드로이드 스플래시 이미지 문의 드립니다. [2] 타락천사 2015.03.09 1351
692 xe10.1에서 ActiveX , *.ocx 설치방법 부탁합니다 [3] 모나도 2016.11.04 1352
691 [안드로이드] 앱 배포후 업데이트시 overwrite 안됩니다.해결방법좀 알려주세요 ㅠ. [2] 한사람 2016.03.27 1353
690 DataSnap에서 NetWork 여러개인 경우 파빌신 2014.04.30 1357
689 [세미나] XE7에서는 컴파일 크기가 개선되었나요? [1] Humphery 2014.09.17 1363
688 환경파일에서 "The imported project file could not be loaded. '', hexadecimal value 0x01, is an invalid character." 오류 발생 시 조치사항 [4] Humphery 2014.11.28 1363
687 Beacon, Bluetooth, Bluetooth LE 동시 접속 문의 [2] 이정이남편 2015.08.25 1366
686 WINEXEC 관련해서 문의드립니다 [3] file jcitec 2015.05.16 1367
685 [세미나] 코드아카데미(BaaS 온라인 강의) 질문답변 Humphery 2014.07.30 1373
684 XE6 ScrollBox 문의드립니다. file 신동근 2014.10.22 1374
683 실행파일 output 경로설정을 하고싶습니다. [4] 불청객 2015.08.04 1376
682 바코드로부터 입력과 키보드 입력을 어떻게 구분하나요? [1] from5 2016.01.09 1378
681 des암호화 복구화 대해서 알고 싶습니다 [1] 헨씀히포 2017.02.28 1381
680 Delphi5, Paradox DB이용한 32bit 프로그램... [1] LucyKim 2014.08.19 1390