팬텀리드 해결 예시 질문
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 공저자(백은빈)가 작성한 한국어 설명, 그림과 예시가 풍부합니다
아주 작은 정오표 전달드립니다.
0
32
2
mysql워크벤치를 실행할때마다 오류가 뜹니다. 해결 방법좀 가르켜주세요.
0
35
1
온톨로지 구축
0
23
1
실제로 작은 기업에서 기획 롤
1
22
1
order_product 까마귀발
0
40
2
공통 코드 , 계층 구조 질문
1
34
1
[DB설계] 탈퇴 유저의 구독 정보 유지 및 이메일 마스킹 관련 질문입니다.
0
51
1
자연키 vs 대리키 실무질문
0
28
1
페이징 처리에서 offset/limit에 대한 질문
1
52
1
1:N 관계에서 중간테이블 (연관엔티티)
0
53
2
dvdrental 서버에 접속할 수 없어요
0
41
1
공통코드 관련한 질문 드립니다.
0
69
1
질문있습니다.
1
61
2
usecase 사용 기준
1
65
2
실습용 테이블, 데이터 생성 파일 있을까요?
2
57
2
MySql
1
55
2
최신버젼 다운로드
0
50
2
차단 등 검증 로직의 위치
0
64
2
멀티스레드
1
58
2
성능 오버헤드
1
53
2
volatile에 대해 질문 있습니다.
2
85
2
Mark and Sweep
1
59
1
GC 알고리즘
1
60
2
용어 질문
1
39
1

