메뉴 건너뛰기

조회 수 9170 추천 수 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 하는 값이 바뀔 때마다 트리거 값도 같이 바꿔줘야 한다는 거겠죠.

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


  1. No Image 11Sep
    by
    2016/09/11 Views 8049 

    Oracle DB 언어셋 설정

  2. Oracle DB 에서 Toad 를 사용하여 Procedure 디버깅 하기

  3. Oracle DBMS_CRYPTO 사용하기 - 암복호화 하기

  4. No Image 11Sep
    by
    2016/09/11 Views 7492 

    oracle listener 로그 형식 - oracle 11g 이전 versioin의 형식으로 변경

  5. No Image 11Sep
    by
    2016/09/11 Views 10650 

    oracle log 보기 - alert, trace

  6. Oracle SQL Developer 도구 활용하기 - Part1

  7. Oracle SQL Developer 도구 활용하기 - Part2

  8. No Image 11Sep
    by
    2016/09/11 Views 8014 

    oracle user 관리

  9. Oracle XDB 리스너 포트 바꾸기

  10. No Image 11Sep
    by
    2016/09/11 Views 8526 

    oracle 구동 방법 및 재부팅 시 oracle 자동 시작 설정 ( /etc/rc.local )

  11. Oracle 시퀀스 생성, 추가, 삭제

  12. No Image 08Dec
    by
    2016/12/08 Views 7023 

    oracle 에서 Index를 이용해서 즉 힌트와 rownum을 이용하여 게시판 작성하기

  13. No Image 30Aug
    by
    2016/08/30 Views 8335 

    Oracle 에서 NVL, NVL2 함수 사용하는 예제

  14. Oracle 에서 테이블과 리소스의 존재 여부를 알아보는 쿼리

  15. No Image 29Aug
    by
    2016/08/29 Views 7140 

    Oracle 저장 프로시저 샘플

  16. oracle 특수문자 입력시 Substitution Variable 변수치환을 없애는 방법

  17. Oracle에서 Foreign Key가 걸려있는 컬럼값 업데이트(update) 하기

  18. Oracle에서 ORA-28000: 계정이 잠금되었습니다. - 해결 방법

  19. Oracle에서 사용자가 생성한 모든 Table, View를 삭제하는 쿼리 만들기

  20. Oracle에서 세자리 콤마 찍기

Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved