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 만 사용할 수도 있습니다.)
'Programming > DataBase' 카테고리의 다른 글
[MSSQL] 계층형 트리구조 쿼리 (0) | 2015.02.03 |
---|---|
[mysql] 문자열의 일부를 반환하는 substr, substring_index 함수 (0) | 2014.10.17 |
oracle 11g 서버 설치방법 (0) | 2014.08.01 |
CREATE TABLESPACE & CREATE USER (0) | 2014.07.13 |
[oracle] decode 함수 (0) | 2014.04.04 |