inflearn logo
강의

講義

知識共有

チャネルトークの面接官が直接教えるCS面接対策 - データベース編

(深掘り質問) なぜInnoDBはREPEATABLE READだけでPhantom Readを解決できるのでしょうか? ⭐️

팬텀리드 해결 예시 질문

解決済みの質問

53

Cola

投稿した質問数 39

1

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

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

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

dbms/rdbms nosql computer-science

回答 1

1

jayon0927

안녕하세요, 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

자세한 설명 감사합니다!

아주 작은 정오표 전달드립니다.

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