티스토리 뷰

AI/SQL

[SQL] UPSERT

brave_sol 2025. 2. 24. 14:13

장소를 저장할 때, 기존에 저장되어 있는 장소면 장소의 id를 반환하고, 등록된 장소가 아니라면 새로 생성하고 id를 반환하고 싶었다. 하지만 단순히 조회 후 저장을 구현하면, 매번 2번의 쿼리가 발생할 수 있고, 동시성 문제가 발생할 수 있는데, Unique 제약조건과 UPSERT 구문을 사용하면 단일 쿼리를 구성하고 DB 자체의 제약조건을 활용해 데이터의 정합성을 보장할 수 있다.

 

1. 조회 후 저장 방식

SELECT id FROM places WHERE name = ? AND address = ?
IF NOT EXISTS -> INSERT INTO places ...

 

2. Unique 제약조건 + UPSERT 방식

- INSERT 시도 후, 중복이면 UPDATE를 실행 : 두 작업이 원자적으로 실행된다.

CREATE TABLE places (
    id INT PRIMARY KEY,
    name VARCHAR(255),
    address VARCHAR(255),
    UNIQUE(name, address)
);

INSERT INTO places (...) ON DUPLICATE KEY UPDATE id=LAST_INSERT_ID(id)
반응형

'AI > SQL' 카테고리의 다른 글

[SQL] 리눅스(ubuntu)에 mysql 설치, SQL 기본 문법  (0) 2025.04.08
[SQL] 데이터와 정보  (0) 2025.04.07
[SQL] MySQL 계정 생성 및 외부 접속  (0) 2025.01.20
[SQL] DB 설계  (2) 2025.01.13
[SQL] capital gain loss  (1) 2024.12.26
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/04   »
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
글 보관함