이 섹션은 방법을 설명합니다ECPG토토 캔적으로 작동합니다. 이 정보는 때때로 사용자가 사용 방법을 이해하는 데 도움이 될 수 있습니다ECPG.
처음 4 줄ECPG
출력에는 고정 라인이 있습니다. 두 개는 주석이며 2 개는 라이브러리 인터페이스에 필요한 줄이 포함되어 있습니다.
Exec SQL
진술, 개입하고 변경합니다. 명령은로 시작합니다.Exec SQL
로 끝납니다;
. 그 사이의 모든 것은로 취급됩니다.SQL가변 대체에 대한 진술 및 구문 분석.
토토 캔 대체는 기호가 결장으로 시작할 때 발생합니다 (:
). 해당 이름의 변수는 이전에 a 내에서 선언 된 변수들 사이에서 위로 올라갑니다.Exec SQL 선언
섹션.
라이브러리에서 가장 중요한 기능은입니다.ecpgdo
, 대부분의 명령을 실행하는 것을 관리합니다. 가변적인 수의 인수가 필요합니다.
인수는 다음과 같습니다.
이것은 원래 줄의 줄 번호입니다. 오류 메시지에만 사용됩니다.
이것이SQL발행 될 명령. 입력 토토 캔, 즉 컴파일 시간에 알려지지 않았지만 명령에 입력 해야하는 토토 캔에 의해 수정됩니다.?
.
모든 입력 토토 캔로 인해 10 개의 인수가 생성됩니다. (아래 참조)
ecpgt_eoit
anenum
더 이상 입력 토토 캔가 없다고 말합니다.
모든 출력 토토 캔로 인해 10 개의 인수가 생성됩니다. (아래 참조)이 변수는 함수에 의해 채워집니다.
ecpgt_eort
anenum
더 이상 토토 캔가 없다고 말합니다.
의 일부인 모든 토토 캔에 대해SQL명령, 함수는 10 개의 인수를 얻습니다.
특수 기호로 유형.
값 또는 포인터에 대한 포인터에 대한 포인터.
토토 캔의 크기는입니다.char
또는varchar
.
배열의 요소 수 (배열 가져 오기)
배열의 다음 요소로의 오프셋 (배열 페치 용).
특수 기호로서 표시기 토토 캔의 유형.
지표 토토 캔에 대한 포인터
0
표시기 배열의 요소 수 (배열 페치 용).
표시기 배열의 다음 요소로의 오프셋 (배열 페치 용)..
모든 SQL 명령이 이러한 방식으로 처리되는 것은 아닙니다. 예를 들어 :과 같은 열린 커서 문화
Exec SQL Open커서
;
는 출력에 복사되지 않습니다. 대신, 커서의선언
명령은의 위치에서 사용됩니다.Open
실제로 커서를 열기 때문에 명령.
여기 파일의 전처리기의 출력을 설명하는 완전한 예foo.pgc
(세부 사항은 사전 처리기의 각 특정 버전에서 변경 될 수 있음) :
Exec SQL 시작 선언 섹션;
로 번역됩니다 :
/ * ECPG에 의해 처리 됨 (2.6.0) */
(여기서 인기가 가독성을 위해 추가되어 전처리가하는 것이 아닙니다.)
문서에 올바른 것이 없으면 일치하지 않습니다.이 양식문서 문제를보고하려면