티스토리 뷰
장소를 저장할 때, 기존에 저장되어 있는 장소면 장소의 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
링크
TAG
- 프로그래머스
- 줄넘기
- 오블완
- 빅데이터 분석기사
- 다이어트
- 오픽
- 루틴
- 습관
- ChatGPT
- 티스토리챌린지
- 뉴스
- 실기
- 운동
- 기초
- 아침
- SQL
- C언어
- Ai
- 아침운동
- 갓생
- 경제
- IH
- 고득점 Kit
- 스크랩
- opic
- 영어회화
- llm
- Python
- 미라클모닝
- 30분
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함