기록하기

MariaDB - INSERT ON DUPLICATE KEY UPDATE 본문

computer science/database

MariaDB - INSERT ON DUPLICATE KEY UPDATE

jjungdev 2022. 5. 22. 23:06

실무에서 insert 와 update 를 같이 수행시키기 위해 INSERT ON DUPLICATE KEY UPDATE 명령어를 많이 사용하는데, 사용시 PK 를 왜 입력해야하는지에 대해 mariadb 공식 사이트 내용을 정리해보려고 한다.

 


INSERT ON DUPLICATE KEY UPDATE

INSERT ON DUPLICATE KEY UPDATE 명령어는 insert 를 할 때, 중복되는 유니크 키 또는 pk 가 있을 경우에는 update 명령어가 수행되고, 그 외에는 insert 가 수행되는 명령어를 의미한다.

 

예를 들어, Person 클래스가 있고, id 가 pk 일 때 아래와 같이 구성할 수 있다.

public class Person {

    private Long id;
    private String name;
    private String email;
}

 

이 경우에 name 이나 email 을 update 할 경우가 있을 경우 아래와 같이 sql 을 작성한 뒤 update 을 할 때 id 도 같이 전송해주면 새로운 내용일 경우 insert 를, 기존 데이터를 update 하는 경우 update 명령어가 수행될 것이다.

INSERT INTO tb_person
SET id = #{id},
    name = #{name},
    email = #{email}
ON DUPLICATE KEY UPDATE
    name = #{name},
    email = #{email}

 

'computer science > database' 카테고리의 다른 글

식별(강결합)관계와 비식별(약결합) 관계  (0) 2022.06.05
MySQL - CHAR 와 VARCHAR  (0) 2022.05.15