테스트 사이트 - 개발 중인 베타 버전입니다

트리거를 이용하여 날짜 자동 업데이트법

· 12년 전 · 1845 · 1
-- 트리거용 테스트 테이블을 만듭니다
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"
------------------------------------------------------------------------------------------------------------------

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

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

댓글 1개

12년 전
감사합니다.

게시글 목록

번호 제목
18790
JavaScript 공백제거
18788
18786
18783
18780
18769
5549
27272
27267
30785
30782
27264
18767
18765
18764
18763
5546
18760
18758
18755
18752
27256
27247
5539
18750
27244
27243
18749
18747
18745
18741
18740
18738
18731
18730
27240
5535
18728
18726
18724
5532
26500
27237
5529
30776
18721
20725
27232
18719
JavaScript 퀵메뉴 1
18717
18714
18712
18709
27213
27200
18706
18704
18702
18701
18700
18698
18697
18696
18694
5525
27199
18691
5515
5510
5501
18690
18687
5496
18686
18676
26496
18675
30773
18671
30767
18667
18658
18650
18648
5494
5490
20705
5485
18645
27194
20684
18642
5482
27185
5478
5473
5467
18636
5462
5443