-- 트리거용 테스트 테이블을 만듭니다
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'
)
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 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;
UPDATE TriggerTest SET col01 = '012' where pk = 2;
-- 결과를 보도록 하죠.
SELECT * FROM TriggerTest;
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"
------------------------------------------------------------------------------------------------------------------
이 트리거를 좀더 활용하면 특정 테이블에 데이타가 들어오면 자동으로 다른 테이블에 입력, 수정, 삭제도 가능합니다.
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"
------------------------------------------------------------------------------------------------------------------
이 트리거를 좀더 활용하면 특정 테이블에 데이타가 들어오면 자동으로 다른 테이블에 입력, 수정, 삭제도 가능합니다.
이상 허접한 팁이었습니다.
게시글 목록
| 번호 | 제목 |
|---|---|
| 20144 | |
| 20141 | |
| 10871 |
JavaScript
스크립트오류 제거
1
|
| 10869 |
JavaScript
간단한 쿠키지원 팝업 스크립트
1
|
| 10868 | |
| 10867 |
JavaScript
대소문자변환
|
| 10864 | |
| 10862 | |
| 10859 |
JavaScript
홈페이지 브라우저 크기 고정시키기
2
|
| 10856 |
JavaScript
iframe 아이프레임 투명처리
2
|
| 10854 | |
| 10853 |
JavaScript
금액 입력시 자동으로 천단위구분기호(,) 붙여주는 함수
|
| 10851 | |
| 10849 |
JavaScript
출생년도에 따른 나이 계산 자바스크립트
1
|
| 10845 | |
| 10844 | |
| 10842 |
JavaScript
iframe에서 페이지를 닫을 때
1
|
| 10835 |
JavaScript
iframe 높이 자동조절 스크립트
6
|
| 10834 |
JavaScript
자바스크립트 인공지능 장기게임-Minimax
|
| 10832 |
JavaScript
금액을 한글로 표기 해주는 스크립트;
1
|
| 10830 |
JavaScript
전화번호 입력시 자동 하이픈 넣기
1
|
| 10828 |
JavaScript
사업자번호체크스크립트 간단버전
1
|
| 17669 |
견적서
홈페이지 제작 견적서
14
|
| 20135 | |
| 10825 |
jQuery
플러그인 만들기 간단 예제
2
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기