메뉴 건너뛰기

조회 수 9172 추천 수 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
번호 제목 날짜 조회 수
101 오라클 암호 초기화 및 사용자 생성 2016.12.08 8648
100 오라클 백업 및 복구(Export, Import) file 2016.12.08 9762
99 오라클 랜덤함수 2018.10.27 2149
98 오라클 계정 lock 해제 2016.12.08 8444
97 오라클 ORDER BY : 정렬 2017.01.20 8241
96 오라클 NULL : 값이 존재하지 않는 상태 2017.01.20 7201
95 오라클 DB 생성 후 설정 Listener.ora & Tnsnames.ora (윈도우) file 2016.12.08 23308
94 오라클 DB 백업과 복원 2016.12.08 9926
93 오라클 25가지 SQL 작성법 2016.12.08 7706
92 오라클 12c (Oracle) 에서 테스트를 위해 샘플 스키마 설치하기 file 2016.08.30 8929
91 오라클 10, 16진수(Decimal, Hex) 변환 2018.10.27 4288
90 오라클 (Oracle) 쿼리 구간별 시간 체크 하기 file 2016.08.30 7974
89 오라클 (Oracle) 11g 를 위한 토드(Toad) 무료 버전 다운받기 file 2016.08.30 16021
88 오늘을 기준으로 해당주(week)의 모든 일자조회 2016.12.08 7029
87 오늘을 기준으로 해당주(week)의 모든 일자조회 2017.01.20 8329
86 여러개(다중) LIKE 검색 방법 (REGEXP_LIKE 함수) file 2016.12.08 12822
85 엑셀데이타를 DB 에 저장. Excel => oracle db restore 2016.12.08 8744
84 아카이브 백업 / 복구 2016.09.12 6968
83 실수로 지운 데이터 복구 쿼리 (TIMESTAMP) 2016.12.08 11166
82 시퀀스 초기화 프로시저 2016.09.12 8925
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved