C++Builder Programming Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
C++빌더 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
컴포넌트/라이브러리
메신저 프로젝트
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C++빌더 Q&A
C++Builder Programming Q&A
[29470] Re:질문] dbexpress 사용시 exception 처리는 어떻게 하는지요?
박지훈.임프 [cbuilder] 983 읽음    2004-04-23 00:55
Access Violation이 일어난다면 일반적인 디비 예외는 아니지요. 예외처리로 해결할 문제가 아닙니다.
무언가 코드에 중대한 에러가 있다는 말이고요. 제가 보기에는 Execute()를 호출하실 때 sqlParam 인자가
의심스럽군요.

그리고 보통 데이터베이스 관련 에러는 EDatabaseError 클래스로 발생합니다. 그리고 그 안에서 구체적으로
어떤 에러인지는 클래스 종류로 알 수가 없구요. 이것은 데이터베이스 엔진마다(각 RDBMS와 로컬 디비 등)
모두 달라서 VCL에서 핸들할 수 있는 문제가 아니죠. 다만 메시지는 출력할 수 있습니다.

try
{
    SQLConnectioin1.Execute (어쩌구...);
}
catch(EDatabaseError &E)
{
    ShowMessage(E.Message);
    return;
}


초록물고기 님이 쓰신 글 :
: 안녕하세요.
: DBexpress의 컴포넌트 중 SQLConnection을 사용할때, exception 처리는 어떻게 하는지요?
:
:  
:    SQLConnection1->Connected = true;
:    //build SQL command
:    ...
:    SQLConnectioin1.Execute ( SQLCommand, sqlParam , NULL );
:
: 위에서  insert문을 실행하였는데, (DB를 확인해 보니 ) DB에는 정상적으로 데이타가 들어갔는데...
: C++빌더 프로그램에서는 aceess violation 라고 exception을 뿌리면서 죽어버립니다.
: 왜 이런 현상이 일어나는지요?
:
: 또는 unique key때문에 insert 못했을 경우들에 대해서,,,구분해서
: exception을 처리하고 싶은데..
:
: 여기서 try ... catch ()를 사용해야 할 것 같은데... SQL에서 어떤 exception 이 발생하는지..
: 어디서 알아내서.. 어떻게 사용하는지요?
:
:
:
:
:
:
: 감사 합니다.
: 그럼 수고 하세요.
:

+ -

관련 글 리스트
29459 질문] dbexpress 사용시 exception 처리는 어떻게 하는지요? 초록물고기 726 2004/04/22
29470     Re:질문] dbexpress 사용시 exception 처리는 어떻게 하는지요? 박지훈.임프 983 2004/04/23
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.