
MySQL InnoDB의 락킹 메커니즘: 갭락과 넥스트키 락 이해하기
·
Backend Development
서론데이터베이스에서 트랜잭션의 격리성(Isolation)을 보장하기 위한 락킹 메커니즘은 매우 중요합니다. 특히 MySQL InnoDB 엔진은 갭락(Gap Lock)과 넥스트키 락(Next-Key Lock)이라는 독특한 락킹 메커니즘을 제공하여 팬텀 리드(Phantom Read) 현상을 방지합니다. 이 글에서는 이러한 락킹 메커니즘의 개념과 동작 방식을 자세히 살펴보겠습니다.팬텀 리드(Phantom Read)란?팬텀 리드는 트랜잭션 격리성과 관련된 중요한 문제입니다. 이는 다음과 같은 상황에서 발생합니다:트랜잭션 A가 특정 조건으로 데이터를 조회트랜잭션 B가 새로운 데이터를 삽입트랜잭션 A가 동일한 조건으로 다시 조회할 때, 이전에 없던 새로운 데이터가 나타남예시 코드-- 트랜잭션 A 시작START TR..