CREATE LANGUAGE

CREATE LANGUAGE — 새 프로시져 언어 정의

요약

CREATE [ OR REPLACE ] [ PROCEDURAL ] LANGUAGE 이름
CREATE [ OR REPLACE ] [ TRUSTED ] [ PROCEDURAL ] LANGUAGE 이름
    HANDLER 호출핸들러 [ INLINE 인라인핸들러 ] [ VALIDATOR 유효성검사함수 ]

설명

CREATE LANGUAGE 명령은 PostgreSQL 내 함수를 만들거나, DO 명령을 사용할 때 지정하는 프로시져 언어를 만든다. - 새로 만드는 개념보다는 조합해서 그 언어를 사용할 수 있도록 등록한다 - 옮긴이.

참고

PostgreSQL 9.1 이후부터 대부분의 프로시져 언어는 확장 모듈로 관리되기 때문에, CREATE LANGUAGE 명령을 직접 사용하기 보다는 CREATE EXTENSION 명령으로 등록한다. 이렇기 때문에, CREATE LANGUAGE 명령은 그 확장 모듈 설치 스크립트 안에서만 사용되어야 한다. 한편, 이미 확장 모듈로 설치하지 않은 언어가 있다면, CREATE EXTENSION langname FROM unpackaged 명령으로 확장 모듈로 변환해서 사용하는 것이 향후 업그레이드를 위해서 좋다.

CREATE LANGUAGE 명령의 내부 작업은 해당 언어로 작성된 함수 본문을 처리하는 핸들러 함수와 해당 언어 이름의 연결 작업이다. 언어 핸들러에 대한 자세한 설명은 55장에서 다룬다.

사용법은 두 가지 방식이 있는데, 첫번째 문법은 pg_pltemplate 시스템 카탈로그에 미리 정의된 언어를 등록할 때 사용한다. 그냥 언어 이름만 지정하면 된다. 두번째 문법은 pg_pltemplate 시스템 카탈로그에 정의되지 않은 언어를 등록할 때 쓰는 방법인데, 예전 방식이다.

이 명령에서 해당 언어 관련 여러 옵션을 함께 사용했다 하더라도, pg_pltemplate 카탈로그에 등록되어 있는 언어라면, 카탈로그 정보를 이용해서 언어를 등록한다. 이렇게 하는 이유는 오래된 버전의 덤프 파일을 새 버전에서 복원할 때 보다 안전하게 복원하기 위함이다.

통상, 새 언어 등록은 PostgreSQL 슈퍼유저 권한이 있어야 가능하다. 한편, pg_pltemplate 카탈로그에서 tmpldbacreate 칼럼값이 true인 언어에 대해서는 데이터베이스 소유주도 자신의 데이터베이스 내에서는 그 언어를 등록할 수 있다. 데이터베이스 소유주가 등록할 수 있는 언어는 신뢰할 수 있는 (tmpltrusted 칼럼값이 true인) 것이여야 한다. 물론 슈퍼유저는 pg_pltemplate 내용을 바꿀 수 있다. 해당 언어를 등록한 사용자가 그 언어의 소유주가 되며, 삭제, 이름 변경, 소유주 변경 작업을 할 수 있는 권한을 가진다.

CREATE OR REPLACE LANGUAGE 구문은 없으면 새 언어로 등록하고, 있으면, 그 정의를 바꾼다. 이때 이미 있어 정의가 변경 될 때는 pg_pltemplate 내에 정의된 정보로 바꾼다. 이때, 소유주, 접근 권한은 바뀌지 않는다. 기존에 있는 그 언어용 함수들은 여전히 유효한 것으로 간주한다. 추가로 REPLACE인 경우에도, 그 접근권한은 새로 등록할 때와 같다. 슈퍼유저이거나, 해당 언어의 소유주여야 한다. REPLACE 구문은 주로 해당 언어가 이미 있어도 이 작업을 오류로 처리하지 않게 하려고 사용한다. pg_pltemplate 안에 등록된 언어라면, 특별한 경우를 제외하고는 REPLACE 작업으로 변경되는 것은 없다. 물론 앞에서 설명한 대로 기존 언어가 pg_pltemplate에서 정의된 정보와 다른 경우는 등록 정보가 변경 된다.

매개 변수

TRUSTED

TRUSTED 옵션을 사용하면, 그 사용자가 사용하면 안될 자료에 접근을 금지한다. 이 키워드가 빠지면, PostgreSQL 슈퍼유저만 이 언어를 이용해서 새 함수를 만들 수 있다.

PROCEDURAL

호환성을 위해 있는 키워드. 무시함.

이름

새 프로시져 언어 이름. 이 이름은 해당 데이터베이스 내에 유일해야 한다.

하위 호환성을 위해, 이 이름은 작은 따옴표로 둘러 쌀 수도 있다.

HANDLER 호출핸들러

호출핸들러는 이 언어를 사용하는 함수에서 그 함수 본문을 처리할 함수 이름이다. 이 호출 핸들러 함수는 C 언어로 작성되며, PostgreSQL C 언어 함수 버전 1 규칙으로 만들어야 하며, 입력 인자는 없고, 반환 자료형은 language_handler 형이다. 이 자료형은 이 함수가 호출 핸들러로 사용됨을 식별하기 위한 자료형이다.

INLINE 인라인핸들러

인라인핸들러DO 명령에서 사용하는 코드 블럭을 처리할 때 사용하는 함수 이름이다. 인라인핸들러 함수를 지정하지 않으면, DO 명령에서 해당 언어를 사용할 수 없게 된다. 이 함수의 입력 인자는 internal 형 하나를 사용하며, 반환 값은 void다. 핸들러의 반환값은 무시된다.

VALIDATOR 유효성검사함수

유효성검사함수는 한 함수가 만들어질 때, 함수 본문의 구문 검사를 하는 함수 이름이다. 이 함수를 지정하지 않으면, 새 함수를 만들 때, 유효성 검사를 하지 않는다. 이 유효성 검사 함수의 입력 인자는 만들어지는 함수의 OID를 넘겨 받는 oid 형 인자 하나이고, 반환은 void 다.

이 유효성 검사 함수는 함수 본문 내 문법 검사를 주로 담당하지만, 그 외 함수 여러 속성들도 함께 검사하기도 한다. 예를 들어, 해당 언어가 처리할 수 없는 자료형이 함수의 입력 인자로 사용되는 것을 막는데도 사용된다. 유효성 검사의 오류 처리는 이 함수 내 ereport() 함수 호출로 한다. 이 함수 반환 값은 무시된다.

TRUSTED 옵션과 지원 함수들은 그 언어가 pg_pltemplate 내에 미리 정의된 것이라면, 무시된다.

참고

프로시져 언어를 지울 때는 DROP LANGUAGE 명령을 사용한다.

현재 설치된 언어의 등록 정보는 pg_language 시스템 카탈로그에 보관된다(51.29절 참조). 또한 psql에서 \dL 명령어로 설치된 언어를 살펴볼 수도 있다.

해당 언어용 함수를 만들 때는 사용자가 그 언어에 대해 USAGE 권한이 있어야 한다. 신뢰할 수 있는 trusted 언어는 기본적으로 USAGE 권한이 PUBLIC(모든 사용자)에게 부여된다. 이 권한은 필요 하다면 도로 거둘 revoke 수 있다.

프로시져 언어는 각 데이터베이스 별로 설치해서 사용한다. 자주 쓰는 언어라면, template1 데이터베이스에 미리 설치해서, 새로운 데이터베이스를 만들 때 그 언어를 설치해야하는 번거로움을 줄일 수 있다.

pg_pltemplate 카탈로그에 미리 정의된 언어가 아닌 경우, 그 언어를 등록할 때 필요한 호출 핸들러 함수, 인라인 핸들러 함수(필요하다면), 유효성 검사 함수(필요하다면)는 먼저 그 데이터베이스에 있어야 한다. 반면, pg_pltemplate 카탈로그에 정의된 언어를 등록(설치)하는 경우는 그 관련 함수들을 따로 만들어(설치) 둘 필요는 없다. 해당 데이터베이스에 없으면 자동으로 만든다. (그 언어용 공유 라이브러리를 사용할 수 없는 경우, - 설치가 잘못된 경우 CREATE LANGUAGE 명령은 실패한다.)

PostgreSQL 7.3 이전 버전에서는 핸들러 함수의 반환 자료형이 language_handler가 아니라, opaque였다. 오래된 버전의 덤프 파일의 호환성을 위해서, 이 경우도 허용하기는 하지만, language_handler 형으로 바꾸라는 알림 메시지를 보여준다.

예제

표준 프로시져 언어인 경우는 다음과 같이 간단하게 만들 수 있음:

CREATE LANGUAGE plperl;

pg_pltemplate 카탈로그에 없는 언어인 경우는 다음과 같은 방식으로 등록한다:

CREATE FUNCTION plsample_call_handler() RETURNS language_handler
    AS '$libdir/plsample'
    LANGUAGE C;
CREATE LANGUAGE plsample
    HANDLER plsample_call_handler;

호환성

CREATE LANGUAGE 구문은 PostgreSQL 확장 기능이다.

관련 항목

ALTER LANGUAGE, CREATE FUNCTION, DROP LANGUAGE, GRANT, REVOKE