Docs Menu
Docs Home
/
MongoDB Compass
/

색인 관리

이 페이지의 내용

  • Indexes Tab
  • 인덱스 만들기
  • 인덱스 숨기기 또는 숨기기 해제
  • 색인 제거
  • 제한 사항

인덱스는 쿼리 성능을 향상시키는 특수 데이터 구조입니다.인덱스는 컬렉션 데이터의 일부를 탐색하기 쉬운 형태로 저장합니다. 인덱스는 특정 필드 또는 필드 집합의 값을 필드 값에 따라 정렬하여 저장합니다.

쿼리 성능을 개선하려면 쿼리에 자주 나타나는 필드와 필드를 기준으로 정렬 하는 모든 작업에 대해 인덱스를 구축합니다.

  • 인덱스된 필드에 대한 쿼리는 인덱스를 사용하여 일치하는 문서를 찾기 위해 스캔해야 하는 문서 수를 제한할 수 있습니다.

  • 인덱스된 필드에 대한 정렬 작업은 인덱스에 의해 미리 정렬된 문서를 반환할 수 있습니다.

인덱스에 대해 자세히 알아보려면 인덱스를 참조하세요.

참고

고려 사항

인덱스는 쓰기 작업에 일부 부정적인 성능 영향을 미칩니다. 쓰기 대 읽기 비율이 높은 컬렉션의 경우 각 삽입은 인덱스도 업데이트해야 하므로 비용이 많이 듭니다. 인덱스에 대한 자세한 고려 사항 목록은 인덱스 운영 고려 사항을 참조하세요.

Indexes 탭에는 컬렉션의 기존 인덱스가 나열됩니다.

컬렉션의 Indexes 탭에 액세스하려면 왼쪽 창에서 컬렉션을 클릭하고 Indexes 탭을 선택하세요.

인덱스 보기
클릭하여 확대

각 인덱스에 대해 Compass는 다음 정보를 표시합니다:

이름 및 정의
인덱스 이름 및 키.
유형
일반, 텍스트, 지리적 공간 또는 해시 인덱스.
size
인덱스의 크기.
사용법
인덱스가 생성된 이후 또는 마지막 서버 재시작 이후 인덱스가 조회에 사용된 횟수입니다.
속성
인덱스의 모든 특수 속성(예: 고유성, 부분)입니다.
1

인덱스 탭에서 Create Index 버튼을 클릭합니다.

2
  1. 인덱스 키를 지정합니다.

    • 기존 문서 필드를 인덱스 키로 지정하려면 드롭다운 목록에서 필드를 선택합니다.

    • 어떤 문서에도 존재하지 않는 필드를 인덱스 키로 지정하려면 입력 상자에 필드 이름을 입력합니다.

    • 복합 인덱스를 생성하려면 인덱스 유형 드롭다운 옆에 있는 아이콘을 클릭합니다.

  2. 각 필드 이름 오른쪽에 있는 드롭다운을 사용하여 인덱스 유형을 지정합니다. 다음 유형 중 하나를 지정할 수 있습니다.

    • 오름차순

    • 내림차순

    • 2dsphere

    • Text

다음도 참조하세요.

와일드카드 인덱스를 지정하는 방법을 알아보려면 와일드카드 인덱스 만들기를 참조하세요.

3

Compass는 다음과 같은 인덱스 옵션을 지원합니다:

옵션
설명
자세한 정보
고유 인덱스 만들기
인덱싱된 필드에 중복된 값이 저장되어 있지 않은지 확인합니다.
인덱스 이름
인덱스의 이름을 지정합니다.
TTL 인덱스 생성
인덱싱된 필드 값 이후 지정된 시간(초)이 지나면 문서를 자동으로 삭제합니다.
부분 필터 표현식

지정된 필터 표현식과 일치하는 문서만 인덱싱합니다.

예를 들면 다음과 같습니다.

다음 부분 필터 표현식은 timezone 필드가 존재하는 문서만을 인덱싱합니다.

{ "timezone": { "$exists": true } }
와일드카드 프로젝션(MongoDB 4.2의 새로운 기능)

이 인덱스에 지정된 프로젝션과 일치하는 미확인 필드 또는 임의 필드를 지원합니다. 와일드카드 프로젝션을 사용하려면 인덱스 필드 이름을 $**(으)로 설정하세요. 이렇게 하면 Compass가 문서의 모든 필드를 사용할 수 있게 됩니다(예외: _id).

예를 들면 다음과 같습니다.

다음 와일드카드 프로젝션 문서를 고려하세요:

{
"product_attributes.elements" : 1,
"product_attributes.resistance" : 1
}

인덱스 필드 이름이 $** 인 경우 인덱스에는 해당 프로젝션 필드의 값만 포함됩니다.

사용자 지정 데이터 정렬 사용
텍스트 상자에 데이터 정렬 문서를 입력하거나 붙여 넣어 인덱스에 대한 사용자 지정 데이터 정렬을 만듭니다.
4

Atlas Search 인덱스를 사용하면 Atlas Search에서 데이터를 쿼리할 수 있습니다. 자세한 내용은 Atlas Search 인덱스 생성 및 관리를 참조하세요.

Atlas Vector Search 인덱스를 사용하면 벡터 데이터 기타 데이터 유형을 인덱싱할 수 있으므로 인덱싱된 필드에서 시맨틱 검색이 용이합니다. 자세한 내용은 Atlas Vector Search 인덱스 생성을 참조하세요.

버전 v4.2에 추가.

알 수 없거나 임의의 필드에 대한 쿼리를 지원하기 위해 와일드카드 인덱스를 생성할 수 있습니다. Compass에서 와일드 카드 인덱스를 만들려면 Select a field name 입력에 와일드카드 인덱스 필드(<field>.$**)를 수동으로 입력합니다.

예시

문서에 userMetadata 객체가 포함된 컬렉션을 고려해 보세요. userMetadata 객체 내의 필드는 문서마다 다를 수 있습니다.

userMetadata에 와일드카드 인덱스를 만들어 객체 내의 모든 잠재적 필드를 고려할 수 있습니다. Select a field name 입력란에 다음을 입력합니다.

userMetadata.$**

와일드 카드 인덱스의 유형(ascending 또는 descending)을 지정한 다음 Create Index를 클릭합니다.

Compass에서 새 인덱스의 유형을 Wildcard로 표시합니다.

쿼리 플래너에서 인덱스 숨기기를 실행하면 실제로 인덱스를 제거하지 않고도 인덱스 제거의 잠재적 영향을 평가할 수 있습니다.

1

Indexes 탭에서 숨기려는 인덱스 위로 마우스를 가져갑니다.

2

선택한 인덱스 위로 마우스를 가져가면 나타나는 오른쪽 눈 감기 아이콘을 클릭하세요.

3

대화 상자에서 숨기려는 인덱스를 확인합니다. 선택을 확인하면 Properties 열 아래에 Hidden 배지가 나타납니다.

인덱스 숨기기를 해제하려면 1~3단계를 반복합니다. 인덱스 숨기기를 해제하면 Compass가 Properties 열에서 Hidden 배지를 제거합니다.

1

인덱스 탭에서 인덱스를 삭제하려면 해당 인덱스의 휴지통 아이콘을 클릭합니다. 확인 대화 상자가 나타납니다.

2

대화 상자에서 삭제할 인덱스의 이름을 입력합니다.

3
  • MongoDB Compass Readonly Edition에서는 인덱스 생성, 숨기기 및 제거가 허용되지 않습니다.

  • Data Lake에 연결되어 있는 경우 Indexes 탭을 사용할 수 없습니다.

  • 배포가 로컬이고 Atlas 클러스터 계층이 M10 이상이고 MongoDB 7.0 이상을 실행하는 경우 Compass에서 Atlas Search 색인을 관리할 수 있습니다.

    이전 버전의 MongoDB 를 실행 하는 클러스터의 경우, Atlas UI, Atlas CLI 또는 Atlas Administration API를 사용하여 Atlas Search 인덱스를 관리 할 수 있습니다.

돌아가기

AI & Data Usage