inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

채널톡 면접관이 직접 알려주는 CS 면접 대비 - 데이터베이스 편

(꼬리 질문) 왜 InnoDB는 REPEATABLE READ만으로도 Phantom Read를 해결할 수 있나요? ⭐️

팬텀리드 해결 예시 질문

22

Cola

작성한 질문수 39

1

Select for update where id = 5 는 id 5만 보이는데 팬텀리드의 예시랑 관련이 있나요?

그리고 이상황에 갭 락이 걸리나요?

레코드락만 걸리지 않나요?

dbms/rdbms nosql computer-science

답변 1

1

JSCODE 제이온

안녕하세요, 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)로 교체하고, 위의 락 동작 정리 표를 보강 자료로 추가해두겠습니다. 디테일까지 정확하게 짚어주신 덕분에 자료가 한 단계 더 정밀해질 것 같아요. 정말 감사합니다!

 

참고 링크

  1. MySQL 공식 매뉴얼 17.7.3 — 표의 모든 케이스가 명시되어 있습니다

  2. 당근 테크 블로그 — MySQL Gap Lock 다시보기Real MySQL 8.0 공저자(백은빈)가 작성한 한국어 설명, 그림과 예시가 풍부합니다

0

Cola

자세한 설명 감사합니다!

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