- Today
- Total
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Link
- 재능이의 돈버는 일기
- StresslessLife
- K_JIN2SM
- 소소한 일상
- My Life Style & Memory a Box
- Blog's generation
- 공감 스토리
- 취객의 프로그래밍 연구실
- Love Me
- Dream Archive
- 세상에 발자취를 남기다 by kongmingu
- hanglesoul
- 카마의 IT 초행길
- 느리게.
- 미친듯이 즐겨보자..
- Joo studio
- Gonna be insane
- 악 다 날아갔어!! 갇대밋! 왓더...
- xopowo05
- 맑은공기희망운동
- 엔지니어 독립운동
- 혁준 블로그
- Simple in Complex with Simple
- 무의식이 의식을 지배한다
드럼치는 프로그래머
[DBMS] 오라클 MERGE INTO - 한번에 INSERT, UPDATE 하기 본문
DB 테이블을 다룰 때, 특정 조건의 데이터가 존재하는 경우에는 해당 row를 원하는 값으로 update하고, 없는 경우에는 새로운 데이터를 insert를 해야하는 경우가 왕왕 있습니다. 이럴 때 보통은 select 쿼리를 먼저해보고 데이터가 있는지 없는지 판단을 해서 update를 할 지 insert를 할 지 분기해서 처리했었는데요. oracle에서 MERGE INTO라는 구문을 쓰면 하나의 쿼리로 두가지 경우에 모두 대처할 수 있습니다.
아래와 같이 쓰면 됩니다. table을 지정했기 때문에 MATCHED, NOT MATCHED 이하에 update문과 insert문에 table_name은 생략됩니다.
MERGE INTO table_name alias
USING (table | view | subquery) alias -- 하나의 테이블만 이용한다면 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 실행
USING (table | view | subquery) alias -- 하나의 테이블만 이용한다면 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 실행
예 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, ...... );
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', ...... );
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', ...... );
Oracle 10g 이후에는 WHEN MATCHED, WHEN NOT MATCHED 이하의 update, insert 구문에도 where절을 쓸 수 있습니다.
출처: http://unabated.tistory.com/entry/오라클-MERGE-INTO-한번에-INSERT-UPDATE-하기 [랄라라]
'★─Programing > ☆─DBMS' 카테고리의 다른 글
[DBMS] MySql, SQLException, Column 'COL_NM' not found (0) | 2017.06.08 |
---|---|
[DBMS] MSSQL between을 이용한 날짜 검색 (0) | 2017.06.07 |
[DBMS] MSSQL IDENTITY 값 초기화 (0) | 2017.04.04 |
[DBMS] MySQL - INFORMATION_SCHEMA 사용법 (0) | 2017.03.23 |
[DBMS] varchar 값을 변환하는 중 int 열이 오버플로되었습니다. 최대 정수 값을 초과했습니다. (0) | 2017.03.21 |
Comments