메뉴 건너뛰기

조회 수 9167 추천 수 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
번호 제목 날짜 조회 수
21 TOAD 에서 Edit 를 통해 sql문을 작성할때 참고해야할 View file 2016.08.30 7468
20 Oracle에서 사용자가 생성한 모든 Table, View를 삭제하는 쿼리 만들기 file 2016.08.29 7464
19 Create SYNONYM 2016.09.12 7411
18 기간내 모든 날자(일자) 구하기 2016.12.08 7358
17 Oracle에서 ORA-28000: 계정이 잠금되었습니다. - 해결 방법 file 2016.08.29 7323
16 오라클 암호를 분실한 경우 접속 방법 2016.09.21 7274
15 자동증가 SEQUENCE 생성 2016.09.12 7249
14 오라클(PL/SQL) 미리 정의된 예외처리 2016.12.08 7215
13 오라클 NULL : 값이 존재하지 않는 상태 2017.01.20 7201
12 제로보드 reg_date 필드 date 형으로 변환하기 2016.09.12 7168
11 Oracle 저장 프로시저 샘플 2016.08.29 7140
10 ORA-28001: the password has expired - 추천 실적용 실전 2016.12.08 7078
9 PK 수정하기 2016.09.12 7069
8 오늘을 기준으로 해당주(week)의 모든 일자조회 2016.12.08 7029
7 oracle 에서 Index를 이용해서 즉 힌트와 rownum을 이용하여 게시판 작성하기 2016.12.08 7023
6 DB Link How-To 2016.09.12 7015
5 아카이브 백업 / 복구 2016.09.12 6968
4 SQL 작성을 위한 25가지 원칙 2016.12.08 6908
3 Oracle Batch Processing 2016.12.08 6822
2 오라클 10, 16진수(Decimal, Hex) 변환 2018.10.27 4284
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved