Drop Database

MERGE 를 이용한 ROW INSERT OR UPDATE

한알두알 2007. 9. 20. 11:45
Merge를 사용하여 row 삽입
merge를 하려고 하는 source 테이블의 행을 읽어 target 테이블에 매치되는 행이 있을 경우에는 새로운 값으로 UPDATE를 수행하고,
만일 매치되는 행이 없을 경우에는 새로운 행으로 인식하여 target 테이블에 INSERT를 수행한다.

merge 문을 수행하기 위해서는 다음과 같은 권한이 주어져야 한다.
• target 테이블 새로운 행을 삽입하기 위한 insert 권한.
• target 테이블에서 기존 행을 갱신하기 위한 update 권한.
• source 테이블 행을 검색하기 위한 select 권한.

【형식】
	MERGE INTO 테이블명 alias
	USING [테이블명 | 뷰명 | subquery] alias
on 조건
	WHEN MATCHED THEN
		UPDATE SET ...
	WHEN NOT MATCHED THEN
		INSERT ...
		VALUES ...;
• merge into 뒤에 테이블을 삽입하거나 target 테이블명을 지정한다.
• WHERE 절은 사용할 수 없고, 대신 on 절에 JOIN 조건을 기술한다.
• WHEN MATCHED THEN 절에는 on 절에서 기술한 JOIN 조건을 만족하는 즉, source 테이블과 target 테이블간에 매치되는 행이 존재할 경우 target 테이블의 행을 새로운 값으로 UPDATE하기 위한 구문을 기술한다.
• WHEN NOT MATCHED THEN 절에는 on 절에서 기술한 JOIN 조건을 만족하지 않는 경우 즉, target 테이블에 행을 INSERT하기 위한 구문을 기술한다.
• WHEN MATCHED THEN 절과 WHEN NOT MATCHED THEN 절에는 테이블명 대신 alias를 사용한다.

【예제】
SQL> create table dept1
  2  AS select * from dept;
테이블이 생성되었습니다.
SQL> create table dept2
  2  AS select * from dept;
테이블이 생성되었습니다.
SQL> insert into dept2 values(50,'KIM_gun','COREA');
1 개의 행이 만들어졌습니다.
SQL> update dept2 
  2  set dname='LEE_gun' where deptno=30;
1 행이 갱신되었습니다.
SQL> select * from dept2;
    DEPTNO DNAME          LOC
---------- -------------- -------------
        10 ACCOUNTING     NEW YORK
        20 RESEARCH       DALLAS
        30 LEE_gun        CHICAGO
        40 OPERATIONS     BOSTON
        50 KIM_gun        COREA
SQL> select * from dept1;
    DEPTNO DNAME          LOC
---------- -------------- -------------
        10 ACCOUNTING     NEW YORK
        20 RESEARCH       DALLAS
        30 SALES          CHICAGO
        40 OPERATIONS     BOSTON
SQL> merge into dept1 d
  2  using dept2 de
  3  on (d.deptno=de.deptno)  ☜ on 조건절에 들어 있는 컬럼은 update절에 넣으면 오류발생
  4  when matched then
  5  update set
  6   d.dname=de.dname,
  7   d.loc=de.loc
  8  when not matched then
  9   insert values(de.deptno, de.dname, de.loc);
5 행이 병합되었습니다.
SQL> select * from dept1;
    DEPTNO DNAME          LOC
---------- -------------- -------------
        10 ACCOUNTING     NEW YORK
        20 RESEARCH       DALLAS
        30 LEE_gun        CHICAGO
        40 OPERATIONS     BOSTON
        50 KIM_gun        COREA
SQL> 

테이블 aa
1111 홍길동
2222 길동무
3333 죽마고우
테이블 aa를 bb로 merge
====================>
merge전 bb의 내용
1111 홍길동
2222 옛친구
테이블 bb의 값이 바뀜
====================>
merge후 bb의 내용
1111 홍길동
2222 길동무
3333 죽마고우

SQL> create table aa(id number(4), name varchar2(10));
테이블이 생성되었습니다.
SQL> create table bb (id number(4), name varchar2(10));
테이블이 생성되었습니다.
SQL> insert into aa values(1111,'홍길동');
1 개의 행이 만들어졌습니다.
SQL> insert into aa values(2222,'길동무');
1 개의 행이 만들어졌습니다.
SQL> insert into aa values(3333,'죽마고우');
1 개의 행이 만들어졌습니다.
SQL> insert into bb values(1111,'홍길동');
1 개의 행이 만들어졌습니다.
SQL> insert into bb values(2222,'옛친구');
1 개의 행이 만들어졌습니다.
SQL> select * from aa;
        ID NAME
---------- ----------
      1111 홍길동
      2222 길동무
      3333 죽마고우
SQL> select * from bb;
        ID NAME
---------- ----------
      1111 홍길동
      2222 옛친구
SQL> merge into bb target
  2  using aa source
  3  on (source.id=target.id)
  4  when matched then
  5    update set
  6     target.name=source.name
  7  when not matched then
  8    insert values(source.id,source.name);
3 행이 병합되었습니다.
SQL> select * from bb;
        ID NAME
---------- ----------
      1111 홍길동
      2222 길동무
      3333 죽마고우
SQL> 

'Drop Database' 카테고리의 다른 글

케릭터셋 인코딩  (0) 2007.10.05
SQL PLUS 잡다한 기능  (0) 2007.09.20
MERGE INTO  (0) 2007.09.20
오라클 접속방법  (0) 2007.09.20
오라클 힌트 사용법  (0) 2007.09.20