이 문서는 지원되지 않는 버전의 PostgreSQL을위한 것입니다.
당신은에 대해 같은 페이지를 보려고 할 수 있습니다postgresql : 문서 : 17 : 토토 사이트 추천버전 또는 위에 나열된 다른 지원 버전 중 하나입니다.

사설 토토 사이트

이름

사설 토토 사이트- 명령 실행

시놉시스

int 사설 토토 사이트 (const char *명령, boolread_only, Longcount)

설명

사설 토토 사이트지정된 SQL 명령count행. 만약에read_onlyistrue, 명령은 읽기 전용 및 실행이어야합니다 오버 헤드가 다소 줄어 듭니다.

이 함수는 연결된 A에서만 호출 될 수 있습니다 절차.

ifcount명령은 0입니다 적용되는 모든 행에 대해 실행됩니다. 만약에count는 0보다 크다 명령이 실행되는 것을 위해 제한되어 있습니다 (aLimit절). 예를 들어,

사설 토토 사이트 ( "foo에 삽입 *에서 * 삽입 *에서 삽입", false, 5);

표에 최대 5 행을 삽입 할 수 있습니다.

하나의 문자열로 여러 명령을 전달할 수 있습니다.사설 토토 사이트명령의 결과를 반환합니다 마지막으로 실행되었습니다. 그만큼count제한이 적용됩니다 각 명령에 별도로 있지만 숨겨진에 적용되지 않습니다. 규칙에 의해 생성 된 명령.

언제read_onlyisfalse, 사설 토토 사이트명령 카운터를 증가시키고 새로 계산합니다스냅 샷에서 각 명령을 실행하기 전에 끈. 전류가 있으면 실제로 스냅 샷이 변경되지 않습니다 트랜잭션 격리 수준은SERIALIZALE하지만읽기 헌신적인모드 스냅 샷 업데이트는 각 명령을 허용합니다 다른 사람의 새로 커밋 된 거래 결과를 참조하십시오 세션. 이것은 일관된 행동에 필수적입니다 명령은 데이터베이스를 수정합니다.

whenread_onlyistrue, 사설 토토 사이트스냅 샷 또는 명령 카운터를 업데이트하지 않습니다. 평범한만 허용select명령 명령 문자열에 나타납니다. 명령은 주변 쿼리를 위해 이전에 설정된 스냅 샷. 이것 실행 모드는 명령 당 오버 헤드 제거. 또한 진정으로 허용안정적인빌드 할 기능 : 이후 연속적인 실행은 모두 동일한 스냅 샷을 사용할 것입니다. 결과에 변화가 없습니다.

일반적으로 읽기 전용과 읽기 쓰기를 혼합하는 것은 현명하지 않습니다 SPI를 사용한 단일 함수 내 명령; 그 결과가 발생할 수 있습니다 읽기 전용 쿼리는 그렇지 않기 때문에 매우 혼란스러운 동작 읽기 쓰기가 수행 한 데이터베이스 업데이트 결과를 확인하십시오. 쿼리.

(마지막) 명령이 있었던 실제 행 수 실행 된 Global Variable에서 실행 된SPI_PROCESSED(반환 값이 아닌 한 함수는spi_ok_utility). 만약 함수의 반환 값은입니다.spi_ok_select그런 다음 글로벌 포인터를 사용할 수 있습니다spitupletable *spi_tuptable액세스 결과 행.

구조spitupletableis 이렇게 정의 됨 :

typedef struct

    MemoryContext tuptabcxt;    / * 결과 테이블의 메모리 컨텍스트 */
    UINT32 할당;        / * 할당 된 vals 수 */
    UINT32 무료;           / * 무료 VAL의 수 */
    tupledesc tupdesc;        / * 행 설명자 */
    heppuple *vals;           / * 행 */
 spitupletable;

vals는 다양한 포인터입니다 줄. (유효한 항목의 수는에 의해 제공됩니다.SPI_PROCESSED.)Tupdesc전달할 수있는 행 디스크립터입니다 줄을 다루는 SPI 기능.tuptabcxt, 할당무료SPI 발신자가 사용하기위한 내부 필드입니다.

SPI_FINISH모든 것을 해방spitupletable전류 중에 할당되었습니다 절차. 특정 결과 테이블을 일찍 자유롭게 해제 할 수 있습니다. 전화를 통해 끝났습니다SPI_FREETUPTABLE.

인수

const char *명령

실행 할 명령 포함

boolread_only

true읽기 전용 실행

Longcount

처리 또는 반환 할 최대 행 수

반환 값

명령의 실행이 성공적이면 다음 (음이 아닌) 값이 반환됩니다.

spi_ok_select

if aselect(하지만선택) 실행

spi_ok_selinto

if a선택실행

SPI_OK_DELETE

if a삭제실행

SPI_OK_INSERT

IF an삽입실행

SPI_OK_UPDATE

IF an업데이트실행

spi_ok_utility

유틸리티 명령 인 경우 (예 :생성 테이블) 실행

오류에서 다음 음의 값 중 하나는입니다 반품 :

SPI_ERROR_ARGUMENT

if명령isNULL또는countis 0 미만

SPI_ERROR_COPY

ifstdout에 복사또는stdin에서 복사시도되었습니다

SPI_ERROR_CURSOR

if선언, 닫기, 또는Fetch시도

SPI_ERROR_TRANSACTION

트랜잭션 조작과 관련된 명령이있는 경우 시도 (시작, 커밋, 롤백, SavePoint, 거래 준비, 준비, 롤백 준비또는 모든 변형

SPI_ERROR_OPUNKNOWN

명령 유형을 알 수없는 경우 (발생하지 않아야합니다)

SPI_ERROR_UNCONNECT

연결되지 않은 절차에서 호출 된 경우

노트

함수사설 토토 사이트, SPI_EXEC, 사설 토토 사이트_PLANSPI_EXECP둘 다 변경SPI_PROCESSEDandSPI_TUPTable(내용이 아닌 포인터입니다 구조의). 이 두 가지 글로벌 변수를 로컬에 저장하십시오 절차 변수 결과 테이블에 액세스 해야하는 경우사설 토토 사이트또는 관련 함수 나중에 전화를 걸어.