본문 바로가기
개발/MySql

Trigger (트리거)

by 꼼냥냥 2022. 4. 15.
728x90

Trigger (트리거)

  • 데이터베이스 트리거(Database Trigger)는 테이블에 대한 이벤트에 반응해 자동으로 실행되는 작업을 의미
  • 테이블에 DML문(Insert, Update, Delete 등) 이벤트가 발생될 때 작동
  • 테이블에 부착되는 프로그램 코드
  • 자기가 직접 실행 불가. 테이블에 이벤트 일어나야 자동 실행
  • IN, OUT 매개 변수를 사용할 수 없음
  • MySQL은 View에 트리거 부착 불가!!!

트리거 종류

행 트리거

  • 테이블 안의 영향을 받은 행 각각에 대해 실행된다.
  • 변경 전 또는 변경 후의 행은 OLD, NEW라는 가상 줄 변수를 사용하여 읽을 수 있다
  • old
  •   - 예전 데이터 즉, delete 로 삭제 된 데이터 또는 update 로 바뀌기 전의 데이터
  • new
  •   - 새 데이터 즉, insert 로 삽입된 데이터 또는 update 로 바뀐 후의 데이터
트리거 이벤트 OLD NEW
INSERT X O
UPDATE O O
DELETE O X

* update일 경우, 기존의 데이터(old)를 새로운데이터로(new)로 교체하는 거니까 old, new 둘다 쓸 수 있다.
* 하지만 delete일경우 기존 데이터를 삭제하는 거니 new를 인식할수가 없다.
* insert역시 새로 삽입하는거니 old가 있을리 없다.

문장 트리거

  • INSERT, UPDATE, DELETE 문에 대해 한번만 실행된다
  • 삽입, 갱신 또는 삭제되는 행 수에 관계없이 각 트랜잭션에 대해 명령문 레벨 트리거가 한 번 실행된다.

BEFORE 또는 AFTER
: 트리거가 실행되는 시기를 지정한다.

  • after 트리거 : 쿼리 이벤트 작동하기 후
  • before 트리거 : 쿼리 이벤트 작동하기 전에 -> 미리 데이터를 확인 가능!

INSTEAD OF
: 트리거를 원래 문장 대신 수행한다.

WHEN
: 트리거를 시작하는 조건식을 지정한다.

BEFORE INSERT, AFTER INSERT,
BEFORE UPDATE, AFTER UPDATE,
BEFORE DELETE, AFTER DELETE
트리거가 존재 한다.


트리거 문법

트리거 생성

DELIMITER $$
CREATE TRIGGER update_item
AFTER UPDATE ON sale_table -- {BEFORE | AFTER} {INSERT | UPDATE| DELETE } 중 언제 어떤 작업을 할지 정한다
FOR EACH ROW -- 아래 나올 조건에 해당하는 모든 row에 적용한다는 뜻
BEGIN
IF NEW.discount_rate != OLD.discount_rate THEN
UPDATE item_table SET discount_rate = NEW.discount_rate WHERE discount_rate = OLD.discount_rate;
END IF;
END $$
DELIMITER ;

BEGIN~END 사이에 조건문과 실행문을 작성한다.
sale_table 테이블의 변경 전/후를 기준으로 필드 앞에 변경 전은 OLD, 변경 후는 NEW 키워드가 붙는다
따라서 IF NEW.discount_rate != OLD.discount_rate THEN의 의미는,
sale_table의 AFTER UPDATE 후 discount_rate 필드의 값과 변경 전 discount_rate 필드의 값이 불일치한다는 조건을 의미한다.
이 조건을 만족하는 row는 IF문 아래 작성된 UPDATE 쿼리문을 실행하게 된다.

트리거 실행

TRIGGER update_item 은 AFTER UPDATE ON sale_table 이 실행되면
자동으로 트리거가 작동하는 구조라, 당연히 sale_table에 update쿼리를 주면 된다.

UPDATE sale_table SET ... WHERE ...;

트리거 확인

show triggers;

트리거 삭제

DELETE TRIGGERS;
728x90

'개발 > MySql' 카테고리의 다른 글

쿼리 실행 계획 분석  (0) 2023.04.26
Qurey 최적화  (0) 2023.04.26
저장 함수(Stored Function)  (0) 2022.04.15
저장 프로시저(Store Procedure)  (0) 2022.04.14
쿼리 작성 및 최적화  (0) 2022.04.13

댓글