PostgreSQL-트리거

PostgreSQL Triggers 지정된 데이터베이스 이벤트가 발생할 때 자동으로 수행 / 호출되는 데이터베이스 콜백 함수입니다.

다음은 PostgreSQL 트리거에 대한 중요한 사항입니다.

  • PostgreSQL 트리거를 실행하도록 지정할 수 있습니다.

    • 작업이 행에서 시도되기 전 (제약 조건이 확인되고 INSERT, UPDATE 또는 DELETE가 시도되기 전)

    • 작업이 완료된 후 (제약 조건이 확인되고 INSERT, UPDATE 또는 DELETE가 완료된 후)

    • 작업 대신 (보기에서 삽입, 업데이트 또는 삭제하는 경우)

  • FOR EACH ROW로 표시된 트리거는 작업이 수정하는 모든 행에 대해 한 번씩 호출됩니다. 반대로 FOR EACH STATEMENT로 표시된 트리거는 수정하는 행 수에 관계없이 주어진 작업에 대해 한 번만 실행됩니다.

  • WHEN 절과 트리거 조치 모두 양식의 참조를 사용하여 삽입, 삭제 또는 업데이트되는 행의 요소에 액세스 할 수 있습니다. NEW.column-nameOLD.column-name여기서 column-name은 트리거가 연결된 테이블의 열 이름입니다.

  • WHEN 절이 제공되면 지정된 PostgreSQL 문은 WHEN 절이 참인 행에 대해서만 실행됩니다. WHEN 절이 제공되지 않으면 모든 행에 대해 PostgreSQL 문이 실행됩니다.

  • 동일한 이벤트에 대해 동일한 종류의 여러 트리거가 정의 된 경우 이름에 따라 알파벳 순서로 실행됩니다.

  • BEFORE, AFTER 또는 INSTEAD OF 키워드는 연관된 행의 삽입, 수정 또는 제거와 관련하여 트리거 조치가 실행되는시기를 결정합니다.

  • 트리거는 연관된 테이블이 삭제 될 때 자동으로 삭제됩니다.

  • 수정할 테이블은 트리거가 연결된 테이블 또는 뷰와 동일한 데이터베이스에 있어야하며 tablename, 아닙니다 database.tablename.

  • CONSTRAINT 옵션이 지정되면 제약 트리거 가 생성 됩니다 . 이는 SET CONSTRAINTS를 사용하여 트리거 발생 타이밍을 조정할 수 있다는 점을 제외하면 일반 트리거와 동일합니다. 제약 조건 트리거는 구현하는 제약 조건을 위반할 때 예외를 발생시킬 것으로 예상됩니다.

통사론

생성의 기본 구문 trigger 다음과 같습니다-

CREATE  TRIGGER trigger_name [BEFORE|AFTER|INSTEAD OF] event_name
ON table_name
[
 -- Trigger logic goes here....
];

여기, event_nameINSERT, DELETE, UPDATE,TRUNCATE에 언급 된 테이블에 데이터베이스 작업을table_name. 선택적으로 테이블 이름 뒤에 FOR EACH ROW를 지정할 수 있습니다.

다음은 다음과 같이 테이블의 하나 이상의 지정된 열에서 UPDATE 작업에 대한 트리거를 생성하는 구문입니다-

CREATE  TRIGGER trigger_name [BEFORE|AFTER] UPDATE OF column_name
ON table_name
[
 -- Trigger logic goes here....
];

COMPANY 테이블에 삽입되는 모든 레코드에 대해 감사 시도를 유지하려는 경우를 고려해 보겠습니다. 다음과 같이 새로 생성합니다 (이미 가지고있는 경우 COMPANY 테이블을 삭제합니다).

testdb=# CREATE TABLE COMPANY(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL
);

감사 시도를 계속하기 위해 새 레코드에 대한 COMPANY 테이블에 항목이있을 때마다 로그 메시지가 삽입되는 AUDIT라는 새 테이블을 생성합니다.

testdb=# CREATE TABLE AUDIT(
   EMP_ID INT NOT NULL,
   ENTRY_DATE TEXT NOT NULL
);

여기서 ID는 AUDIT 레코드 ID이고 EMP_ID는 COMPANY 테이블에서 가져 오는 ID이며 DATE는 레코드가 COMPANY 테이블에 생성 될 때 타임 스탬프를 유지합니다. 이제 다음과 같이 COMPANY 테이블에 트리거를 생성 해 보겠습니다.

testdb=# CREATE TRIGGER example_trigger AFTER INSERT ON COMPANY
FOR EACH ROW EXECUTE PROCEDURE auditlogfunc();

auditlogfunc ()가 PostgreSQL 인 경우 procedure 그리고 다음과 같은 정의가 있습니다-

CREATE OR REPLACE FUNCTION auditlogfunc() RETURNS TRIGGER AS $example_table$
   BEGIN
      INSERT INTO AUDIT(EMP_ID, ENTRY_DATE) VALUES (new.ID, current_timestamp);
      RETURN NEW;
   END;
$example_table$ LANGUAGE plpgsql;

이제 실제 작업을 시작하겠습니다. AUDIT 테이블에 감사 로그 레코드를 생성해야하는 COMPANY 테이블에 레코드 삽입을 시작하겠습니다. 따라서 다음과 같이 COMPANY 테이블에 하나의 레코드를 생성 해 보겠습니다.

testdb=# INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (1, 'Paul', 32, 'California', 20000.00 );

이렇게하면 COMPANY 테이블에 다음과 같은 하나의 레코드가 생성됩니다.

id | name | age | address      | salary
----+------+-----+--------------+--------
  1 | Paul |  32 | California   |  20000

동시에 AUDIT 테이블에 하나의 레코드가 생성됩니다. 이 레코드는 COMPANY 테이블의 INSERT 작업에서 생성 한 트리거의 결과입니다. 마찬가지로 요구 사항에 따라 UPDATE 및 DELETE 작업에 대한 트리거를 만들 수 있습니다.

emp_id |          entry_date
--------+-------------------------------
      1 | 2013-05-05 15:49:59.968+05:30
(1 row)

트리거 나열

현재 데이터베이스의 모든 트리거를 다음에서 나열 할 수 있습니다. pg_trigger 다음과 같이 표-

testdb=# SELECT * FROM pg_trigger;

위에 주어진 PostgreSQL 문은 모든 트리거를 나열합니다.

특정 테이블에 대한 트리거를 나열하려면 다음과 같이 테이블 이름과 함께 AND 절을 사용하십시오.

testdb=# SELECT tgname FROM pg_trigger, pg_class WHERE tgrelid=pg_class.oid AND relname='company';

위의 PostgreSQL 문은 다음과 같이 하나의 항목 만 나열합니다.

tgname
-----------------
 example_trigger
(1 row)

트리거 삭제

다음은 기존 트리거를 삭제하는 데 사용할 수있는 DROP 명령입니다.

testdb=# DROP TRIGGER trigger_name;