ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [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



    댓글 0

work6.kr