IT/Database

[Oracle] Update Select 방법 및 bypass_ujvc

JJo 2019. 2. 18. 15:35

Update Select 방법 1


1
2
3
4
5
UPDATE 테이블A A
SET ( A.업데이트 받을 컬럼 ) = ( SELECT B.업데이트 할 컬럼
                                  FROM 테이블 B B
                                WHERE B.NO = '특정번호' )
WHERE A.NO ='특정번호';
cs




Update Select 방법 2


1
2
3
4
5
6
7
UPDATE 테이블A A
SET ( A.aa, A.bb ) = ( SELECT B.aa, B.bb
                         FROM 테이블 B B
                        WHERE B.id = A.id )
WHERE EXISTS ( SELECT B.aa, B.bb
                 FROM 테이블 B B
                WHERE B.id = A.id )
cs




Update Select 방법 3


1
2
3
4
5
6
UPDATE  /*+ BYPASS_UJVC */      
    (SELECT A.aa, B.bb
        FROM 테이블 A, 테이블 B
        WHERE A.id= B.id
    )
SET    B.aa= A.aa  ;
cs


1. 조인되는 2개의 테이블은  1:1, 1:M의 관계

2. Update되는 테이블은 M쪽 집합


-> 이 말은 1쪽 집합의 조인 컬럼이 PK로 설정되어 있어야 하는건데

이 조건을 만족하지 않으면 키보존 테이블 위배 된다며 에러를 내고 실행되지 않습니다.

(pk로 설정되어 있지 않더라도 사실 상 중복되는 컬럼이 없어도 안된다...)


이것을 회피하게 해주는 힌트가 bypass_ujvc입니다.

오라클 11g이후부턴 merge into사용을 권고하고 

bypass_ujvc힌트는 없어졌습니다.