대부분의 경우 응용 프로그램이 작성된 시점에 응용 프로그램이 실행 해야하는 특정 토토 결과 문이 알려져 있습니다. 그러나 경우에 따라 토토 결과 문은 실행 시간에 구성되거나 외부 소스에 의해 제공됩니다. 이 경우 토토 결과 문을 C 소스 코드에 직접 포함시킬 수는 없지만 문자열 변수에서 제공하는 임의의 토토 결과 문을 호출 할 수있는 시설이 있습니다..
임의의 토토 결과 문을 실행하는 가장 간단한 방법은 명령을 사용하는 것입니다즉시 실행
. 예를 들어:
Exec SQL 시작 선언 섹션; const char *stmt = "생성 테이블 테스트 1 (...);"; Exec SQL END DELLARE SECTION; exec SQL 즉시 실행 : stmt;
즉시 실행
결과 세트를 반환하지 않는 토토 결과 문에 사용할 수 있습니다 (예 : DDL,삽입
, 업데이트
, 삭제
). 데이터를 검색하는 진술을 실행할 수 없습니다 (예 :select
)이 방법. 다음 섹션에서는 그렇게하는 방법에 대해 설명합니다.
임의의 SQL 문을 실행하는보다 강력한 방법은 한 번 준비하고 원하는대로 자주 준비한 문을 실행하는 것입니다. 일반화 된 버전의 명령문을 준비한 다음 매개 변수를 대체하여 특정 버전을 실행할 수도 있습니다. 진술을 준비 할 때 나중에 매개 변수를 대체 할 위치에 대한 물음표를 작성하십시오. 예를 들어:
Exec SQL 시작 선언 섹션; const char *stmt = "test1 값 (?,?)에 삽입;"; Exec SQL END DELLARE SECTION; Exec SQL 준비 mystmt : stmt; ... Exec SQL 42, 'foobar';을 사용하여 Mystmt를 실행합니다.
더 이상 준비된 진술이 필요하지 않은 경우 다음을 처리해야합니다.
Exec 토토 결과 거래 준비 준비이름
;
단일 결과 행이있는 토토 결과 문을 실행하려면execute
를 사용할 수 있습니다. 결과를 저장하려면 AT 추가in
조항
Exec SQL 시작 선언 섹션; const char *stmt = "test1에서 a, b, c를 선택하여 a?"; int v1, v2; Varchar V3 [50]; Exec SQL END DELLARE SECTION; Exec SQL 준비 mystmt : stmt; ... exec SQL MystMt Execute mystmt : v1, : v2, : v3 사용 37;
anexecute
명령은를 가질 수 있습니다.in
절, A사용
조항, 둘 다 또는 둘 다.
쿼리가 둘 이상의 결과 행을 반환 할 것으로 예상되면 다음 예제에서와 같이 커서를 사용해야합니다. (보다섹션 34.3.2커서에 대한 자세한 내용은.)
Exec SQL 시작 선언 섹션; Char Dbaname [128]; char datname [128]; char *stmt = "u.useName as dbaname, d.datname을 선택하십시오" "pg_database d, pg_user u에서" "여기서 d.datdba = u.usesysid"; Exec SQL END DELLARE SECTION; EXEC SQL TestDB에 CON1 사용자 테스트를 사용합니다. Exec SQL 선택 PG_CATALOG.SET_CONFIG ( 'search_Path', '', False); Exec SQL 커밋; Exec SQL STMT1 준비 : STMT; STMT1에 대한 exec SQL 선언 cursor1 커서; Exec SQL Open Cursor1; 찾을 수 없을 때마다 Exec SQL이 중단됩니다. 동안 (1) exec SQL은 cursor1을 가져옵니다 : dbaname, : datname; printf ( "dbaname =%s, datname =%s \ n", dbaname, datname); Exec SQL Close cursor1; Exec SQL 커밋; EXEC SQL 모든 분리;
문서에 맞지 않는 내용이 있으면 일치하지 않습니다. 특정 기능에 대한 귀하의 경험 또는 추가 설명이 필요합니다. 사용이 양식문서 문제를보고하려면