메뉴 건너뛰기

조회 수 9171 추천 수 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
번호 제목 날짜 조회 수
41 오라클(PL/SQL) 미리 정의된 예외처리 2016.12.08 7215
40 오라클 해당 월 의 맨첫날 ~ 마지막 일 가져 오는 쿼리 2016.12.08 8417
39 오라클 암호 초기화 및 사용자 생성 2016.12.08 8648
38 관리자( SYSTEM, SYS) 계정 비밀번호를 잊어버렸을때.. file 2016.12.08 8336
37 ORA-28001: the password has expired - 추천 실적용 실전 2016.12.08 7079
36 계층형 쿼리의 응용 - 달력만들기 file 2016.12.08 8528
35 계층형 쿼리의 응용 - 답변형 계시판 file 2016.12.08 8752
34 날짜관련 계산하기(1) file 2016.12.08 8090
33 [Oracle 12g] 설치 후 오라클 관리자 계정 접속하기 file 2016.12.08 10721
32 [Oracle 12] ORA-01950: 테이블스페이스 'USERS'에 대한 권한이 없습니다. file 2016.12.08 8580
31 Oracle 11g Database에 외부 접속 허용하도록 설정하기 file 2016.12.08 24907
30 Oracle 11g Client Install 및 외부 클라이언트 도구의 사용 file 2016.12.08 70720
29 [Oracle SQL] 여러 행(ROW)을 하나의 컬럼(COLUMN)으로 합치기 (WM_CONCAT) file 2016.12.08 20018
28 오늘을 기준으로 해당주(week)의 모든 일자조회 2016.12.08 7029
27 구분자로 자르기 (Split) file 2016.12.08 20566
26 기간내 모든 날자(일자) 구하기 2016.12.08 7381
25 [Oracle|오라클] 한글 초성 검색 함수 2016.12.08 9089
24 실수로 지운 데이터 복구 쿼리 (TIMESTAMP) 2016.12.08 11166
23 INSTR 문자열의 뒤(마지막)에서 부터 문자 찾기 (right to left, last) file 2016.12.08 14893
22 동적쿼리(Dynamic SQL) 사용법 (텍스트 쿼리) file 2016.12.08 15037
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved