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 만 사용할 수도 있습니다.)
그럼...
[출처] - http://blog.naver.com/crossbow71?Redirect=Log&logNo=60148709714
'프로그래밍 > SQL' 카테고리의 다른 글
오라클(Oracle) 한글 깨짐 현상 처리 (0) | 2013.11.13 |
---|---|
주말을 제외한 전 영업일자 SQL (0) | 2013.11.13 |
오라클(Oracle) 잡(Job) 스케줄러 구성 (0) | 2013.11.13 |
오라클(Oracle) 날짜계산 (0) | 2013.11.11 |
오라클(Oracle) REPLACE 함수와 TRANSLATE 함수의 문자 치환 (0) | 2013.11.11 |
댓글