|
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 이 발생하는지..
: 어디서 알아내서.. 어떻게 사용하는지요?
:
:
:
:
:
:
: 감사 합니다.
: 그럼 수고 하세요.
:
|