팬텀리드 해결 예시 질문
22
작성한 질문수 39
Select for update where id = 5 는 id 5만 보이는데 팬텀리드의 예시랑 관련이 있나요?
그리고 이상황에 갭 락이 걸리나요?
레코드락만 걸리지 않나요?
답변 1
1
안녕하세요, Cola님!
정확히 짚어주셨습니다. 좋은 지적 감사합니다.
말씀하신 대로 SELECT ... FOR UPDATE WHERE id = 5에서 id가 PK이고 해당 row가 존재한다면, InnoDB는 갭락 없이 레코드 락만 걸립니다. MySQL 공식 매뉴얼(17.7.3 Locks Set by Different SQL Statements in InnoDB)에도 명시되어 있는 동작이에요.
"For a unique index with a unique search condition, InnoDB locks only the index record found, not the gap before it."
실제로 performance_schema.data_locks 테이블에서 확인하시면 X, REC_NOT_GAP(record lock only)으로 찍히는 케이스에 해당합니다.
전체 락 동작을 정리하면 다음과 같습니다.
InnoDB 락 동작 정리 (REPEATABLE READ 기준)
Unique Index + 정확한 값 + row 존재 => Record lock만 (갭락 X)
Unique Index + 정확한 값 + row 없음 => Gap lock
Non-Unique Index => Next-key lock (Record + Gap)
범위 조건 (BETWEEN, >, < 등) => Next-key lock (Record + Gap)
InnoDB가 팬텀 리드를 막기 위해 기본적으로 next-key lock을 사용하는 큰 그림은 그대로 맞지만, 질문하신 케이스(Unique Index 단일 매치)는 유일성 보장 자체가 팬텀을 원천 차단하기 때문에 InnoDB가 최적화로 레코드 락만 거는 예외 케이스에 해당해요.
자료의 예시(WHERE id = 5)는 next-key lock이 실제로 걸리는 케이스(범위 조건 또는 Non-Unique Index)로 교체하고, 위의 락 동작 정리 표를 보강 자료로 추가해두겠습니다. 디테일까지 정확하게 짚어주신 덕분에 자료가 한 단계 더 정밀해질 것 같아요. 정말 감사합니다!
참고 링크
MySQL 공식 매뉴얼 17.7.3 — 표의 모든 케이스가 명시되어 있습니다
당근 테크 블로그 — MySQL Gap Lock 다시보기 — Real MySQL 8.0 공저자(백은빈)가 작성한 한국어 설명, 그림과 예시가 풍부합니다
usecase 사용 기준
0
2
0
실습용 테이블, 데이터 생성 파일 있을까요?
1
8
2
MySql
1
14
2
최신버젼 다운로드
0
20
2
차단 등 검증 로직의 위치
0
30
2
멀티스레드
1
22
2
성능 오버헤드
1
29
2
volatile에 대해 질문 있습니다.
2
39
2
Mark and Sweep
1
35
1
GC 알고리즘
1
32
2
용어 질문
1
26
1
일대일 fk 위치
0
30
1
호출횟수 질문입니다.
1
37
2
실행과정 질문입니다.
2
39
1
수업에서 사용하는 툴 질문드려요
0
40
2
다음 강의는 언제쯤 나올까요?
0
50
2
강의자료 문의
0
21
1
제 3 정규형 vs BCNF 정규형 차이점?
0
45
3
DESC, ASC
0
35
2
수파베이스 ORM 질문
0
34
2
FOREIGN KEY 정리하기, 영상대로 SQL코드 복붙해도 안되요.
0
21
1
트리거 질문
0
32
1
Substack 1년 제공
1
39
3
특별 학습 자료 프로모션 1년 멤버십 무료 제공 문의드립니다
0
34
2





