일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
- 자바스크립트
- 6월 공모주 청약 일정
- 제이쿼리
- 코드이그나이터
- css
- 7월 공모주 청약 일정
- Stock ipo
- 리눅스
- 공모주 청약
- 맥
- codeigniter
- 공모주
- IPO
- html
- 주식
- JavaScript
- 오라클
- 자바
- MYSQL
- Eclipse
- 주식 청약 일정
- 주식 청약
- Oracle
- Stock
- php
- linux
- SQL
- java
- 공모주 청약 일정
- jquery
- Today
- Total
개발자의 끄적끄적
[sql/oracle] 오라클 MERGE INTO 문으로 있으면 UPDATE 없으면 INSERT 한번에 수행하기 [펌] 본문
[sql/oracle] 오라클 MERGE INTO 문으로 있으면 UPDATE 없으면 INSERT 한번에 수행하기 [펌]
테이블에 데이터가 이미 존재하면 업데이트 하고, 존재하지 않으면 입력을 해야 하는 경우가 종종 있습니다. 오라클에서 이런 작업을 한번에 할 수 있는 쿼리가 MERGE INTO 문 입니다.
현실적인 예는 아니지만 간단하게 성적 테이블을 생각해 보겠습니다. 과정코드과 학생코드가 주키이고, 성적 필드를 가지고 있습니다.
CREATE TABLE TB_SCORE (
COURSE_ID VARCHAR2(10) NOT NULL,
STUDENT_ID VARCHAR2(10) NOT NULL,
SCORE NUMBER(5, 2) NULL,
CONSTRAINT PK_SCORE PRIMARY KEY (COURSE_ID, STUDENT_ID)
);
1. 동일한 테이블 구조를 가지고 있는 TMP_SCORE 테이블로부터 데이터를 옮기는 예입니다.
TMP_SCORE 테이블에 있는것과 동일한 과정코드와 학생코드를 가진 데이터가 TB_SCORE에 있으면 SCORE 를 업데이트하고, 없으면 입력합니다.
MERGE INTO TB_SCORE S
USING TMP_SCORE T
ON (S.COURSE_ID = T.COURSE_ID AND S.STUDENT_ID = T.STUDENT_ID)
WHEN MATCHED THEN
UPDATE SET S.SCORE = T.SCORE
WHEN NOT MATCHED THEN
INSERT (S.COURSE_ID, S.STUDENT_ID, S.SCORE)
VALUES (T.COURSE_ID, T.STUDENT_ID, T.SCORE)
;
USING 절에는 테이블외에 뷰, 인라인 뷰 등이 올 수도 있습니다.
2. 다른 테이블에서 데이터를 비교하여 가져오는 것이 아니라, 직접 값을 넣고자 한다면 DUAL을 사용할 수 있습니다.
MERGE INTO TB_SCORE S
USING DUAL
ON (S.COURSE_ID = 'C1' AND S.STUDENT_ID = 'S1')
WHEN MATCHED THEN
UPDATE SET S.SCORE = 20
WHEN NOT MATCHED THEN
INSERT (S.COURSE_ID, S.STUDENT_ID, S.SCORE)
VALUES ('C1', 'S1', 20)
;
3. 업데이트나 입력 하나만 할 수도 있습니다.
존재하면 아무것도 하지 않고, 없으면 입력하려면 다음과 같이 합니다.
MERGE INTO TB_SCORE S
USING DUAL
ON (S.COURSE_ID = 'C1' AND S.STUDENT_ID = 'S1')
WHEN NOT MATCHED THEN
INSERT (S.COURSE_ID, S.STUDENT_ID, S.SCORE)
VALUES ('C1', 'S1', 20)
;
ON 뒤에 나오는 매칭 조건은 주키를 사용해야 합니다. 그렇지 않으면 입력시에 중복이 발생하여 에러가 날 수 있습니다.
출처: https://offbyone.tistory.com/253 [쉬고 싶은 개발자]
'개발 > sql' 카테고리의 다른 글
[DB]PL/SQL 프로시저 기초-기본 문법 1 [펌] (0) | 2020.09.21 |
---|---|
[Oracle] 오라클 프로시저(Procedure) 생성 및 실행 (PL/SQL) [펌] (0) | 2020.09.21 |
[sql] PostgreSQL 설치 및 여러가지 사용법 [펌] (0) | 2020.09.18 |
[Oracle] 순위를 반환하는 함수 (RANK, DENSE_RANK, ROW_NUMBER) [펌] (0) | 2020.09.18 |
[Oracle] sqldeveloper로 특수문자 입력[펌] (0) | 2020.09.16 |