강의

멘토링

로드맵

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

아일릿민주님의 프로필 이미지
아일릿민주

작성한 질문수

김영한의 실전 데이터베이스 - 기본편

복합 인덱스 정리

인덱스 설계와 실제 운영의 관계

작성

·

14

0

혹시 테스트 데이터베이스에서 인덱스를 설계하고, EXPLAIN을 통해 점검도 했는데, 실제 서비스 운영에서는 정작 풀 테이블 스캔 결과가 더 빠른 경우가 존재할 수도 있나요?

 

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. 베몬아현아사랑해님.

인덱스는 일반적으로 쿼리의 성능을 개선하기 위한 중요한 도구입니다. 하지만, 모든 상황에서 인덱스가 항상 이점을 제공하는 것은 아닙니다. 다음의 이유로 인해 풀 테이블 스캔이 오히려 더 효율적일 수 있습니다:

  1. 작은 테이블 크기: 테이블이 작다면, 인덱스를 사용하여 검색하는 것보다 그냥 테이블 전체를 스캔하여 검색하는 것이 더 빠를 수 있습니다. 인덱스는 추가적인 I/O 연산을 수반하기 때문에 작은 데이터셋에서는 성능 이점이 줄어들 수 있습니다.

  2. 인덱스가 포함되지 않은 조건: 쿼리 조건에 인덱스가 적용되지 않는 컬럼이 포함되는 경우, 인덱스를 거치기보다는 전체 스캔이 더 효율적일 수 있습니다.

  3. 데이터 편향: 조건문의 특정 값들이 인덱스를 타고 들어가기보다는 경우에 따라 풀 테이블 스캔을 하는 것이 더 나을 수 있습니다. 예를 들어, 클러스터링이 안 된 상태에서 인덱스가 해결책이 되지 않는 경우입니다.

  4. 통계 정보 부정확: 인덱스의 선택도는 데이터베이스 옵티마이저에서 사용되는 통계 정보에 의존합니다. 통계 정보가 최신 상태가 아니면, 옵티마이저가 잘못된 결정을 내릴 수 있습니다.

관련된 주제로 한 질문이 예시 프로젝트와 실제 인덱스 테스트를 통한 최적화 방법을 다루고 있으니 확인해 보시면 도움이 될 것입니다.

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

아일릿민주님의 프로필 이미지
아일릿민주

작성한 질문수

질문하기