Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- springboot
- 비사이드프로젝트
- Spring Reactive Programming
- OAuth2.0
- 사이드 프로젝트
- querydsl
- 2024년 상반기 회고
- 비동기
- Spring Security
- Apple 로그인
- microsoft
- 코드로 배우는 스프링 부트 웹 프로젝트
- 오블완
- FeignClients
- 멀티프로세싱
- ExceptionHandlerFilter
- 멀티태스킹
- 티스토리챌린지
- 프로세스
- 도메인 주도 설계(DDD) 기반 마이크로서비스(MSA) 모델링
- JWT
- asciidoctor
- spring boot
- 멀티스레드
- REDIS
- OpenFeign
- 네이버클라우드 서버
- 스레드
- Spring Cloud OpenFeign
- ExecutorService
Archives
- Today
- Total
기록하기
MariaDB - INSERT ON DUPLICATE KEY UPDATE 본문
실무에서 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 |