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 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 만 사용할 수도 있습니다.)
'Carpe Programming > oracle' 카테고리의 다른 글
[oracle] 문자 설정 변경 (0) | 2012.09.11 |
---|---|
[oracle] tablespace 관련 정보 조회 (0) | 2012.09.06 |
오라클 재시작 (0) | 2012.06.18 |
[oracle] vo 표준 생성 (0) | 2012.03.09 |
[oracle] 데이터 좌/우 reverse 시키키 (0) | 2012.02.17 |