반응형

트리거(Trigger)?

  Table에 어떤 신호가 가해졌을 때 미리 정해진 활동이 자동으로 실행되는 것.

  구체적으로 특정 테이블에 INSERT, DELETE, UPDATE 같은 "DML"문이 수행될 때, 데이터베이스에서 자동으로 동작.

  사용자호출 필요없음, 자동으로 동작!

 

 

기존 테이블

 

1. 테이블에 새로운 사람 가입 (INSERT 문)

INSERT INTO user_address_table VALUES ('1234', 'yoon', 'suwon');
SELECT * FROM user_address_table

 

2. 테이블의 내용 바꾸기 (UPDATE 문)

UPDATE user_address_table SET address = 'busan' WHERE name = 'Yoon'

yoon의 주소가 부산으로 바뀜을 알 수 있다.

반응형

3. 테이블에서 제거하기 (DELETE 문)

DELETE FROM user_address_table WHERE name = 'Yoon';

yoon이 제거됨

 

4. 제거된 사람의 데이터베이스 테이블 추가 (제거된 데이터 까지 관리)

    관리를 위한 새로운 테이블을 생성함!

CREATE TABLE removedName (
	ID char(8),
    Name char(8),
    Address char(20),
    deletedDate date  --  삭제 날
);

 

 

5. 위 과정으로 트리거 생성하기!

DELIMITER //
CREATE TRIGGER check_removed_name
	AFTER DELETE 			-- 삭제 되면 작동
	ON user_address_table		-- 어떤 테이블에?
    FOR EACH ROW			-- 각 row(행) 마다 적용

-- 테이블에 백업데이터 삽입
BEGIN
	INSERT INTO removedName
		VALUES (OLD.ID, OLD.Name, OLD.Address, CURDATE() );
END
// DELIMITER ;

실행시키면 변화없다, 다만 트리거가 실행된 것. 어떤 동작시 작동

 

(테스트 해보기)

이제 user_address_table의 내용을 하나 삭제해본다.

DELETE FROM user_address_table WHERE Name = 'Tom' ;

(결과) 트리거에 의해 자동으로 Tom 데이터가 removedname에 저장됨을 확인 할 수 있다.

 

반응형

+ Recent posts