-
[Oracle] Update Select 방법 및 bypass_ujvcIT/Database 2019. 2. 18. 15:35
Update Select 방법 1
12345UPDATE 테이블A ASET ( A.업데이트 받을 컬럼 ) = ( SELECT B.업데이트 할 컬럼FROM 테이블 B BWHERE B.NO = '특정번호' )WHERE A.NO ='특정번호';cs Update Select 방법 2
1234567UPDATE 테이블A ASET ( A.aa, A.bb ) = ( SELECT B.aa, B.bbFROM 테이블 B BWHERE B.id = A.id )WHERE EXISTS ( SELECT B.aa, B.bbFROM 테이블 B BWHERE B.id = A.id )cs Update Select 방법 3
123456UPDATE /*+ BYPASS_UJVC */(SELECT A.aa, B.bbFROM 테이블 A, 테이블 BWHERE 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힌트는 없어졌습니다.
'IT > Database' 카테고리의 다른 글
[PostgreSQL] 페이징 쿼리 작성하기 (2) 2018.12.16 [PostgreSQL] 특정 위치에서 가까운 거리순 정렬하기 쿼리로만(위도,경도) (0) 2018.12.03 [PostgreSQL] Windows에서 다운로드 및 설치 (+pgAdmin) (0) 2018.10.18 댓글