Inflearn brand logo image

인프런 커뮤니티 질문&답변

정성훈님의 프로필 이미지
정성훈

작성한 질문수

Real MySQL 시즌 1 - Part 1

Ep.01 CHAR vs VARCHAR

레코드 수정시 저장공간이 부족하면

작성

·

23

0

레코드를 저장할 위치가 같은 페이지내에 존재하지 않으면 다른 페이지에 저장될까요?

답변 2

1

이성욱님의 프로필 이미지
이성욱
지식공유자

안녕하세요.

 

1차적으로는 페이지의 데이터를 컴팩션해서 빈 공간을 만들어보고,

그래도 공간이 부족하면 페이지를 스플릿(split)하게 됩니다.

 

감사합니다.

정성훈님의 프로필 이미지
정성훈
질문자

감사합니다 사랑합니다

0

안녕하세요, 인프런 AI 인턴입니다. 정성훈님 반갑습니다!

MySQL에서 레코드가 수정되거나 추가될 때, 해당 레코드를 저장할 수 있는 공간이 원래의 데이터 페이지 내에 부족하다면, 다른 데이터 페이지로 이동하여 저장될 수 있습니다. InnoDB에서는 이러한 경우 Reorganization이라는 작업을 통해 비어있는 공간을 재사용하거나 새로운 페이지로 레코드를 옮겨 저장하게 됩니다.

이러한 방식은 특히 VARCHAR 타입 컬럼의 경우에 두드러지는데, 데이터 크기 증가 등으로 인해 기존 페이지에 수용할 공간이 부족할 때 나타나는 현상입니다.

아래는 관련된 기존 질문과 답변 링크입니다:
- VARCHAR 자리수 변경과 클러스터드 인덱스 구조 유지 - 이 질문에서 VARCHAR 타입의 자리수 변경에 따른 물리적 블록 이동에 대한 설명을 확인하실 수 있습니다.
- VARCHAR와 TEXT 타입의 저장 방식 차이 - CHAR와 VARCHAR, TEXT 타입이 저장되는 방식과 공간 활용에 관한 내용이 포함되어 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

정성훈님의 프로필 이미지
정성훈

작성한 질문수

질문하기