메뉴 건너뛰기

조회 수 9176 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

오라클에서는 Foreign Key가 걸려 있을 경우,

ON UPDATE CASCADE 옵션이 실행되지 않기 때문에 컬럼값을 바꾸기가 쉽지 않습니다.

이때, 트리거를 만들어서 부모테이블이 업데이트 될 때, 자식테이블도 업데이트 되도록 하면 됩니다.


자식테이블 COMTCCMMNDETAILCODE 테이블의 CODE_ID가 현재 Foreign Key구요.

Foreign Key 제약 때문에 UPDATE가 진행되지 않습니다.


부모 : COMTCCMMNCODE.CODE_ID
자식 : COMTCCMMNDETAILCODE.CODE_ID

아래와 같이 트리거를 하나 만들고 UPDATE문을 실행합니다.

CREATE OR REPLACE TRIGGER RENAME_TRIGGER
    AFTER UPDATE ON COMTCCMMNCODE FOR EACH ROW   

    BEGIN        

        UPDATE COMTCCMMNDETAILCODE
              SET CODE_ID = 'INTENTION'
         WHERE CODE_ID = 'INTENT';         

    END;


자, 잘 실행이 될 겁니다.

아래 그림처럼 값이 잘 바뀌어 있습니다.


그리고, 1회용 트리거기 때문에 방금 생성한 트리거를 삭제합니다.


한가지 문제는,,, UPDATE 하는 값이 바뀔 때마다 트리거 값도 같이 바꿔줘야 한다는 거겠죠.

하지만, 임시방편으로 쓸만하다고 봅니다^^


List of Articles
번호 제목 날짜 조회 수
61 쿼리 파싱 시간 측정 - query parsing time 2016.12.08 7704
60 SQL 작성을 위한 25가지 원칙 2016.12.08 6909
59 엑셀데이타를 DB 에 저장. Excel => oracle db restore 2016.12.08 8744
58 오라클 웹로직 12.1.3 설치 방법 file 2016.09.21 9902
57 오라클 암호를 분실한 경우 접속 방법 2016.09.21 7274
56 자동증가 SEQUENCE 생성 2016.09.12 7249
55 테이블 생성(다중 PK) 2016.09.12 7936
54 PK 수정하기 2016.09.12 7069
53 초 이하 단위 시간 얻어오기 2016.09.12 7906
52 V$SESSION 테이블 활용 2016.09.12 8119
51 Database link, Synonym How to 2016.09.12 7500
50 아카이브 백업 / 복구 2016.09.12 6968
49 cron을 이용한 Oracle 백업 2016.09.12 8045
48 시퀀스 초기화 프로시저 2016.09.12 8925
47 TOAD에서 Explain Plan 보기 2016.09.12 8230
46 Create SYNONYM 2016.09.12 7412
45 DB Link How-To 2016.09.12 7015
44 다른 버전의 오라클 import, export 하기 file 2016.09.12 9475
43 제로보드 reg_date 필드 date 형으로 변환하기 2016.09.12 7178
42 오라클 인스턴스 클라이언트(oracle instant client) 2016.09.12 10982
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved