DB 에서 스퀀스를 num_seq라고 만들었다면.. proc에서 (db에서 만들어서 proc에서 별도로 변수를 만들지 않았음) EXEC SQL INSERT INTO table values(num_seq.nextval); 이렇게 사용하니깐 에러가 나더라구요... 원래 잘못된 문장인지,,,정상적인 문장인지... 궁금합니다...
sqlplus 에서도 통하는 정상적인 문장으로 보입니다.
다만 ProC 에서 제가 해보지 않아서 왜 안되는지는 모르겠네요.
EXEC SQL INSERT INTO table (column_name) values (num_seq.nextval);
이렇게 하시고요.. 그리고..proc 에서는 쿼리문 수행후...항상... 오라클 에러 체크 하시는게 좋습니당.....
ex :
.. #define SQLCODE sqlca.sqlcode #define SQLROWS sqlca.sqlerrd[2] #define SQLERRM sqlca.sqlerrm.sqlerrmc .. int main(int argc, char *argv[]) { .... EXEC ORACLE OPTION (ORACA=YES); oraca.oradbgf = 1; /* enable debug operations */ oraca.oracchf = 1; /* gather cursor cache statistics */ oraca.orastxtf = 3; /* always save the SQL statement */ .... EXEC SQL ... if(SQLCODE!=0) { OracleError(sqlca); ... } ... } int OracleError(struct sqlca sqlca ) { sqlca.sqlerrm.sqlerrmc[sqlca.sqlerrm.sqlerrml] = '\0'; oraca.orastxt.orastxtc[oraca.orastxt.orastxtl] = '\0'; oraca.orasfnm.orasfnmc[oraca.orasfnm.orasfnml] = '\0'; if (SQLCODE < 0) { printf("------------------------------------------------------------------------------------"); printf("ORACLE ERROR! CODE = %d", SQLCODE); printf("DESCRIPTION : %s", SQLERRM); printf("IN SQL : %s", oraca.orastxt.orastxtc); printf("ON LINE : %d OF FILE %s",oraca.oraslnr ,oraca.orasfnm.orasfnmc); printf("-------------------------------------------------------------------------------------"); } return SQLCODE; }
Think..
텍스트 포맷에 대한 자세한 정보
<code>
<blockcode>
<apache>
<applescript>
<autoconf>
<awk>
<bash>
<c>
<cpp>
<css>
<diff>
<drupal5>
<drupal6>
<gdb>
<html>
<html5>
<java>
<javascript>
<ldif>
<lua>
<make>
<mysql>
<perl>
<perl6>
<php>
<pgsql>
<proftpd>
<python>
<reg>
<spec>
<ruby>
<foo>
[foo]
문법은 맞는것 같습니다.
sqlplus 에서도 통하는 정상적인 문장으로 보입니다.
다만 ProC 에서 제가 해보지 않아서 왜 안되는지는 모르겠네요.
EXEC SQL INSERT INTO table (column_name)
EXEC SQL INSERT INTO table (column_name) values (num_seq.nextval);
이렇게 하시고요..
그리고..proc 에서는 쿼리문 수행후...항상... 오라클 에러 체크 하시는게 좋습니당.....
ex :
Think..
댓글 달기