본문 바로가기
Programming/DataBase

[oracle] merge into

by 막이 2014. 9. 4.

9i 부터 나온 오라클의 신공 Merge Into.



Merge Into를 사용하면,

커서 돌리며 update하기, insert, update 하기 전 검사 등등을 회피할 수 있습니다.


 

MERGE INTO [테이블명] USING [조회쿼리 또는 Base 테이블

ON [위의 조회쿼리 또는 테이블과의 조인조건]


--ON 다음에 명시한 키와 매치되는 경우 Update처리

WHEN MATCHED THEN 

UPDATE SET  --테이블은 제일 위의 [테이블명]

[컬럼1] = [값1], [컬럼2] = [값2]   

 

DELETE WHERE [추가조건]

 

--ON 다음에 명시한 키와 매치되지 않는 경우 Insert처리

WHEN NOT MATCHED THEN

INSERT (컬럼1,컬럼2,...) --테이블은 제일 위의 [테이블명]

VALUES(값1,값2,...)

 

 

[Sample]

 

MERGE INTO t_Target A

using

(

select key1, key2, value1, value2 

  from t_Base

where key1 = 'abc' 

 

/*

또는 select i_key1 as key1,

       i_key2 as key2

from dual 

*/

) B

ON (A.key1 = B.key1 and A.key2 = B.key2)

 

WHEN MATCHED THEN

 

update set

A.value1 = B.value1,

A.value2 = B.value2

 

 

--(delete는 보통 사용되지는 않지만 필요하면 아래처럼 쓰인다.) 

delete where i_del_gb = 'D' -- i_del_gb 은 SP의 입력 파라메터

 

WHEN NOT MATCHED THEN

insert (A.key1 , A.key2 , A.value1, A.value2)

values (B.key1 , B.key2, B.value1, B.value2)

;

 


즉, [조회쿼리 또는 Base 테이블]과 매치되는 행은 수정 또는 삭제(조건에 따라)되고, 매치되지 않는 행은 추가됩니다.


이제까지 조회후 값이 있으면 수정, 삭제, 없으면 추가를 위해 사용되었던 여러개의 쿼리문이

단 하나의 구문에서 처리된다니... 아름답지 않나요? ^^


(10g에서는 When MATCHED Then 만 사용할 수도 있습니다.)