/*
많은 분들이 아시겠지만 모르시는 분들을 위해 팁에 올립니다.
초보가 아닌 분은 뒤로 버튼을 눌러주시면 되겠습니다 ^^;
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"
------------------------------------------------------------------------------------------------------------------
이 트리거를 좀더 활용하면 특정 테이블에 데이타가 들어오면 자동으로 다른 테이블에 입력, 수정, 삭제도 가능합니다.
이상 허접한 팁이었습니다.
댓글 4개
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 7830 | 9년 전 | 421 | ||
| 7829 |
|
9년 전 | 617 | |
| 7828 | 9년 전 | 540 | ||
| 7827 | 9년 전 | 433 | ||
| 7826 | 9년 전 | 435 | ||
| 7825 | 10년 전 | 481 | ||
| 7824 | 10년 전 | 445 | ||
| 7823 | 10년 전 | 383 | ||
| 7822 | 10년 전 | 362 | ||
| 7821 | 10년 전 | 310 | ||
| 7820 | 10년 전 | 349 | ||
| 7819 |
|
10년 전 | 751 | |
| 7818 | 10년 전 | 390 | ||
| 7817 | 10년 전 | 523 | ||
| 7816 | 10년 전 | 410 | ||
| 7815 | 10년 전 | 608 | ||
| 7814 | 10년 전 | 435 | ||
| 7813 | 10년 전 | 377 | ||
| 7812 | 10년 전 | 403 | ||
| 7811 | 10년 전 | 392 | ||
| 7810 | 10년 전 | 565 | ||
| 7809 | 10년 전 | 496 | ||
| 7808 | 10년 전 | 379 | ||
| 7807 | 10년 전 | 405 | ||
| 7806 |
프로그래머7
|
10년 전 | 1334 | |
| 7805 | 10년 전 | 1276 | ||
| 7804 |
zahir1312
|
10년 전 | 779 | |
| 7803 |
|
10년 전 | 1375 | |
| 7802 | 10년 전 | 460 | ||
| 7801 | 10년 전 | 861 | ||
| 7800 | 10년 전 | 1087 | ||
| 7799 | 10년 전 | 556 | ||
| 7798 | 10년 전 | 512 | ||
| 7797 | 10년 전 | 510 | ||
| 7796 | 10년 전 | 354 | ||
| 7795 | 10년 전 | 506 | ||
| 7794 | 10년 전 | 556 | ||
| 7793 | 10년 전 | 1057 | ||
| 7792 | 10년 전 | 476 | ||
| 7791 | 10년 전 | 557 | ||
| 7790 | 10년 전 | 508 | ||
| 7789 |
fbastore
|
10년 전 | 1449 | |
| 7788 | 10년 전 | 546 | ||
| 7787 | 10년 전 | 402 | ||
| 7786 | 10년 전 | 592 | ||
| 7785 | 10년 전 | 586 | ||
| 7784 | 10년 전 | 646 | ||
| 7783 | 10년 전 | 451 | ||
| 7782 | 10년 전 | 492 | ||
| 7781 | 10년 전 | 899 | ||
| 7780 | 10년 전 | 816 | ||
| 7779 | 10년 전 | 776 | ||
| 7778 | 10년 전 | 364 | ||
| 7777 | 10년 전 | 456 | ||
| 7776 | 10년 전 | 461 | ||
| 7775 | 10년 전 | 411 | ||
| 7774 | 10년 전 | 631 | ||
| 7773 | 10년 전 | 385 | ||
| 7772 | 10년 전 | 735 | ||
| 7771 | 10년 전 | 390 | ||
| 7770 | 10년 전 | 645 | ||
| 7769 | 10년 전 | 382 | ||
| 7768 | 10년 전 | 612 | ||
| 7767 | 10년 전 | 1173 | ||
| 7766 | 10년 전 | 492 | ||
| 7765 | 10년 전 | 529 | ||
| 7764 |
잘살아보자
|
10년 전 | 392 | |
| 7763 |
|
10년 전 | 1457 | |
| 7762 |
Tosea
|
10년 전 | 1056 | |
| 7761 | 10년 전 | 650 | ||
| 7760 |
잘살아보자
|
10년 전 | 677 | |
| 7759 |
잘살아보자
|
10년 전 | 509 | |
| 7758 |
잘살아보자
|
10년 전 | 594 | |
| 7757 | 10년 전 | 1246 | ||
| 7756 |
ITBANK
|
10년 전 | 1252 | |
| 7755 | 10년 전 | 1930 | ||
| 7754 | 10년 전 | 1056 | ||
| 7753 | 10년 전 | 885 | ||
| 7752 | 10년 전 | 1393 | ||
| 7751 |
잘살아보자
|
10년 전 | 534 | |
| 7750 |
잘살아보자
|
10년 전 | 479 | |
| 7749 |
잘살아보자
|
10년 전 | 490 | |
| 7748 |
잘살아보자
|
10년 전 | 496 | |
| 7747 |
잘살아보자
|
10년 전 | 589 | |
| 7746 |
잘살아보자
|
10년 전 | 677 | |
| 7745 |
잘살아보자
|
10년 전 | 917 | |
| 7744 |
잘살아보자
|
10년 전 | 416 | |
| 7743 | 10년 전 | 946 | ||
| 7742 |
starbros
|
10년 전 | 842 | |
| 7741 |
잘살아보자
|
10년 전 | 675 | |
| 7740 |
잘살아보자
|
10년 전 | 543 | |
| 7739 |
잘살아보자
|
10년 전 | 465 | |
| 7738 |
잘살아보자
|
10년 전 | 535 | |
| 7737 |
잘살아보자
|
10년 전 | 501 | |
| 7736 |
잘살아보자
|
10년 전 | 523 | |
| 7735 |
잘살아보자
|
10년 전 | 851 | |
| 7734 |
잘살아보자
|
10년 전 | 431 | |
| 7733 |
잘살아보자
|
10년 전 | 546 | |
| 7732 |
잘살아보자
|
10년 전 | 699 | |
| 7731 |
잘살아보자
|
10년 전 | 625 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기