그냥 개발자 블로그

[Mysql] Mysql 트리거 예제 (테이블 감시) 본문

프로그래밍팁/mysql

[Mysql] Mysql 트리거 예제 (테이블 감시)

마음이파파 2015. 10. 10. 23:24

mysql 테이블 변경 감지

mysql 감시

mysql 테이블 내용 변경되면

mysql 프로그래밍

mysql 데이터 삽입/수정되면 동작



트리거란 특정 DB 테이블을 감시하고 있다가 변화가 감지되면 별도로 정해놓은 프로그램을 실행 시키는 기술




delimiter |

 

CREATE TRIGGER testref BEFORE INSERT ON test1

FOR EACH ROW BEGIN

INSERT INTO test2 SET a2 = NEW.a1;

DELETE FROM test3 WHERE a3 = NEW.a1;

UPDATE test4 SET b4 = b4 + 1 WHERE a4 = NEW.a1;

END;


  • 트리거 만들기
  1. 트리거 이름 "testref"이고, test1테이블의 Insert 트리거를 동작
    1. test2테이블 a2 test1 추가한a1 넣어 Insert .
    2. test3테이블 test1 추가한a1값과 같은 데이터를 지움.
    3. test4테이블 a4 test1 추가한a1 같으면 b4 1 더한다.














/* 

많은 분들이 아시겠지만 모르시는 분들을 위해 팁에 올립니다. 

초보가 아닌 분은 뒤로 버튼을 눌러주시면 되겠습니다 ^^; 

 

mysql 5.x 대부터 많은 변화가 있었는데요 이 중 Trigger에 대해 올릴까 합니다. 

Trigger란 특정 테이블에 입력, 수정, 삭제가 이루어 졌을 경우 특정 명령을 실행하는 기능인데요, 

이 트리거를 이용하여 테이블에 데이타를 수정했을 경우 수정한 날짜를 자동으로 기록하는 예제를 실행해 보도록 하겠습니다. 

 

트리거를 이용하지 않고도 DEFAULT CURRENT_TIMESTAMP UPDATE ON CURRENT_TIMESTAMP 를 사용하면 해결되겠으나, 

이미 입력날짜를 DEFAULT CURRENT_TIMESTAMP로 했을 경우 두 칼럼의 날짜를 자동으로 입력이 불가능할때 사용하시면 되겠습니다. 

 

[mysql]트리거를 이용한 날짜 자동 업데이트 

 

준비사항 : mysql 5.0 이상 

*/ 

 

-- 트리거용 테스트 테이블을 만듭니다 

DROP TABLE TriggerTest; 

CREATE TABLE TriggerTest ( 

  pk INTEGER AUTO_INCREMENT PRIMARY KEY, 

    col01 VARCHAR(12) NOT NULL, 

    regDate TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, -- 입력시 자동으로 날짜를 기입하기 위해 timestamp 타입과 기본 입력값으로 current_timestamp를 사용했습니다 

    modifyDate TIMESTAMP NOT NULL DEFAULT '0000-00-00 00:00:00' 

 

 

-- 트리거를 만듭니다. 

-- 기본 트리거 문법은 CREATE TRIGGER [트리거이름] [BEFORE|AFTER] [INSERT|UPDATE|DELETE] ON [테이블이름] FOR EACH ROW [실행문] 입니다 

-- 

CREATE TRIGGER TRG_TriggerTest_UPDATE 

BEFORE UPDATE ON TriggerTest 

FOR EACH ROW 

BEGIN 

SET NEW.modifyDate = CURRENT_TIMESTAMP; 

END; 

 

 

-- 테스트용 데이타를 입력합니다. 

INSERT INTO TriggerTest SET col01 = '123'; 

INSERT INTO TriggerTest SET col01 = '456'; 

 

SELECT * FROM TriggerTest; 

 

-- 대략 아래와 같이 실행되었으리라 예상합니다. 

pk col01 regDate                   modifyDate 

------------------------------------------------------------------------------------------------------------------ 

1 123 "2008-03-20 오전 11:33:44" '0000-00-00 00:00:00' 

2 456 "2008-03-20 오전 11:33:44" '0000-00-00 00:00:00' 

------------------------------------------------------------------------------------------------------------------ 

 

 

--이제 PK가 2인 COL01 의 칼럼을 수정하겠습니다. 

UPDATE TriggerTest SET col01 = '012' where pk = 2; 

 

-- 결과를 보도록 하죠. 

SELECT * FROM TriggerTest; 

 

아래와 같이 수정한 칼럼의 수정일이 저장되었습니다. 

pk col01 regDate                   modifyDate 

------------------------------------------------------------------------------------------------------------------ 

1 123 "2008-03-20 오전 11:33:44" '0000-00-00 00:00:00' 

2 012 "2008-03-20 오전 11:33:44" "2008-03-20 오전 11:36:34" 

------------------------------------------------------------------------------------------------------------------ 

 

이 트리거를 좀더 활용하면 특정 테이블에 데이타가 들어오면 자동으로 다른 테이블에 입력, 수정, 삭제도 가능합니다. 

 

이상 허접한 팁이었습니다.

 

 

 

 

출처 : http://www.phpschool.com/gnuboard4/bbs/board.php?bo_table=tipntech&wr_id=59982