문서 메뉴
문서 홈
/ / /
Kotlin Sync 드라이버
/

인덱스 작업

이 페이지의 내용

  • 개요
  • 운영 고려 사항
  • 샘플 데이터
  • 인덱스 만들기
  • 인덱스 제거
  • 단일 인덱스 삭제
  • 모든 인덱스 삭제
  • API 문서

이 가이드에서는 Kotlin Sync 드라이버에서 인덱스 를 사용하는 방법을 배울 수 있습니다. 인덱스는 쿼리의 효율성을 높이고 문서 쿼리 및 저장에 기능을 추가할 수 있습니다.

인덱스가 없으면 MongoDB는 컬렉션의 모든 문서를 스캔하여 각 쿼리와 일치하는 문서를 찾아야 합니다. 이러한 컬렉션 스캔은 속도가 느리고 애플리케이션 성능에 부정적인 영향을 미칠 수 있습니다. 그러나 쿼리에 적합한 인덱스가 있는 경우 MongoDB는 인덱스를 사용하여 검사해야 하는 문서를 제한할 수 있습니다.

쿼리 성능을 향상시키려면 애플리케이션의 쿼리와 정렬된 결과를 반환하는 작업에 자주 나타나는 필드에 인덱스를 빌드하세요. 추가하는 각 인덱스는 활성 상태일 때 디스크 공간과 메모리를 사용하므로 용량 계획을 위해 인덱스 메모리와 디스크 사용량을 추적하는 것이 좋습니다. 또한 쓰기 작업이 인덱싱된 필드를 업데이트할 때 MongoDB는 관련 인덱스를 업데이트하므로 쓰기 작업의 성능에 부정적인 영향을 미칠 수 있습니다.

MongoDB 애플리케이션에서 와일드카드 인덱스 를 사용하여 이름이 미리 알려지지 않았거나 임의적인 필드를 쿼리할 수 있습니다. 와일드카드 인덱스는 워크로드 기반 인덱스 계획을 대체하도록 설계되지 않았습니다.

데이터 모델을 설계하고 애플리케이션에 적합한 인덱스를 선택하는 방법에 대한 자세한 내용은 MongoDB Server 매뉴얼의 데이터 모델링 및 인덱스 가이드를 참조하세요.

이 가이드의 예제에서는 Atlas 샘플 데이터 세트sample_mflix 데이터베이스에 있는 movies 컬렉션을 사용합니다. 무료 MongoDB Atlas 클러스터를 생성하고 샘플 데이터 세트를 로드하는 방법을 알아보려면 Atlas 시작하기 가이드를 참조하세요.

MongoDB는 데이터 쿼리에 도움이 되는 여러 가지 인덱스 유형을 지원합니다. 다음 페이지에서는 가장 일반적인 인덱스 유형을 설명하고 각 인덱스 유형을 생성하기 위한 샘플 코드를 제공합니다.

  • 단일 필드 인덱스

  • 복합 인덱스

  • Atlas search 인덱스

_id 필드에서 기본값 고유 인덱스를 제외한 사용하지 않는 인덱스를 제거할 수 있습니다.

다음 섹션에서는 단일 인덱스를 제거하는 방법 또는 컬렉션의 모든 인덱스를 제거하는 방법을 보여 줍니다.

컬렉션에서 인덱스를 제거하려면 인덱스 이름을 dropIndex() 메서드에 전달합니다.

다음 예에서는 movies 컬렉션에서 이름이 "_title_" 인 인덱스를 제거합니다.

collection.dropIndex("_title_")

참고

복합 텍스트 인덱스에서 단일 필드를 제거할 수 없습니다. 인덱스된 필드를 업데이트하려면 인덱스를 전부 삭제하고 새로운 인덱스를 생성해야 합니다.

컬렉션에서 dropIndexes() 메서드를 호출하여 모든 인덱스를 삭제할 수 있습니다.

collection.dropIndexes()

이 가이드에서 사용되는 메서드 또는 유형에 대해 자세히 알아보려면 다음 API 설명서를 참조하세요.

돌아가기

인덱스를 사용하여 쿼리 최적화

다음

단일 필드 인덱스