박미미의 지식에서 쌓는 즐거움

오라클 MERGE INTO 본문

IT 공부

오라클 MERGE INTO

낑깡좋아 2019. 7. 16. 16:15

오라클 MERGE INTO - 한번에 INSERT, UPDATE 하기

출처: https://unabated.tistory.com/entry/오라클-MERGE-INTO-한번에-INSERT-UPDATE-하기 [랄라라]



MERGE INTO table_name alias
            USING (table | view | subqueryalias                -- 하나의 테이블만 이용한다면 DUAL 활용
                 ON (join condition)                                     -- WHERE절에 조건 쓰듯이
            WHEN MATCHED THEN                                   -- ON 이하의 조건에 해당하는 데이터가 있는 경우 
                     UPDATE SET col1 = val1[, ...]                -- UPDATE 실행
            WHEN NOT MATCHED THEN                           -- ON 이하의 조건에 해당하는 데이터가 없는 경우
                     INSERT (column lists) VALUES (values);  -- INSERT 실행

출처: https://unabated.tistory.com/entry/오라클-MERGE-INTO-한번에-INSERT-UPDATE-하기 [랄라라]


예 1) 
MERGE INTO copy_emp c
            USING employees e
            ON (c.employee_id = 200911)
            WHEN MATCHED THEN
                      UPDATE SET
                            c.first_name = e.first_name,
                            c.last_name = e.last_name,
                            c.email = e.email,
                            ......
            WHEN NOT MATCHED THEN
                      INSERT (c.employee_id, c.first_name, c.last_name, ...... ) 
                                 VALUES (e.employee_id, e.first_name, e.last_name, ...... );

예 2) 테이블을 하나만 쓸 경우
MERGE INTO emp
            USING DUAL
            ON (employee_id = 200911)
            WHEN MATCHED THEN
                      UPDATE SET
                            first_name = 'John',
                            last_name = 'Petrucci',
                            email = 'dream@johnpetrucci.com',
                            ......
            WHEN NOT MATCHED THEN
                      INSERT (first_name, last_name, email, ...... ) 
                                 VALUES ('John', 'Petrucci', 'dream@johnpetrucci.com', ...... );



출처: https://unabated.tistory.com/entry/오라클-MERGE-INTO-한번에-INSERT-UPDATE-하기 [랄라라]

Comments