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힌트는 없어졌습니다.