복합 인덱스는 컬렉션 내 각 문서의 여러 필드 값을 수집해 정렬합니다. 복합 인덱스를 사용하여 인덱스의 첫 번째 필드 또는 접두 필드까지 쿼리할 수 있습니다. 복합 인덱스에서 필드의 순서는 매우 중요합니다. 복합 인덱스로 생성된 B-트리는 인덱스에서 지정한 필드 순서대로 정렬된 데이터를 저장합니다.
예를 들어 다음 이미지는 문서가 먼저 userid 기준 오름차순(알파벳순)으로 정렬되는 복합 인덱스를 보여줍니다. 그런 다음 각 userid에 대한 scores를 내림차순으로 정렬합니다.
복합 인덱스를 생성하려면 다음 프로토타입을 사용합니다.
db.<collection>.createIndex( { <field1>: <sortOrder>, <field2>: <sortOrder>, ... <fieldN>: <sortOrder> } )
MongoDB Atlas에서 호스팅되는 배포서버를 위해 UI에서 복합 인덱스를 생성하고 관리할 수 있습니다.
사용 사례
애플리케이션이 여러 필드가 포함된 쿼리를 반복적으로 실행하는 경우, 해당 쿼리의 성능을 개선하기 위해 복합 인덱스를 생성할 수 있습니다. 예를 들어, 식료품점 관리자는 재고가 부족한 품목을 파악하기 위해 이름과 수량으로 재고 품목을 자주 조회할 수 있습니다. 쿼리 성능을 향상시키기 위해 item 및 quantity 필드에 복합 인덱스을 생성할 수 있습니다.
시작하기
복합 인덱스를 만들려면 복합 인덱스 만들기를 참조하세요.
세부 정보
이 섹션에서는 복합 인덱스에 대한 기술적 세부 사항과 제한 사항에 대해 설명합니다.
필드 제한
단일 복합 인덱스에는 최대 32개의 필드가 포함될 수 있습니다.
필드 순서
인덱스된 필드의 순서는 복합 인덱스의 효율성에 영향을 미칩니다. 복합 인덱스에는 인덱스의 필드 순서에 따라 문서에 대한 참고가 포함됩니다. 효율적인 복합 인덱스를 만들려면 ESR(동등성, 정렬, 범위) 지침을 따르세요.
정렬 순서
인덱스는 오름차순(1) 또는 내림차순(-1) 정렬 순서로 필드에 대한 참조를 저장합니다. 복합 인덱스의 경우 정렬 순서에 따라 인덱스가 정렬 작업을 지원하는지 여부가 결정될 수 있습니다. 자세한 내용은 복합 인덱스 정렬 순서를 참조하세요.
해시 인덱스 필드
복합 인덱스에는 단일 해시 인덱스 필드가 포함될 수 있습니다.
인덱스 접두사
인덱스 접두사는 인덱싱된 필드의 시작 부분 집합입니다. 복합 인덱스는 인덱스 접두사에 포함된 모든 필드에 대한 쿼리를 지원합니다.
예를 들어 이 복합 인덱스를 생각해 볼 수 있습니다:
{ "item": 1, "location": 1, "stock": 1 }
인덱스에는 이러한 인덱스 접두사가 있습니다:
{ item: 1 }{ item: 1, location: 1 }
MongoDB는 복합 인덱스를 사용하여 다음 필드 조합에 대한 쿼리를 지원할 수 있습니다.
itemitem개인정보 정책에locationitem,location,stock
item 필드 접두사에 해당하므로 MongoDB 인덱스 사용하여 item 및 stock 필드에 대한 쿼리 지원 수도 있습니다. 그러나 인덱스 { item: 1, stock: 1 }만큼 효율적이지 않습니다.
예를 들어 "item": "saccharomyces cerevisiae" 및 "stock": 60 에 대한 쿼리를 생각해 보겠습니다. collection에 "item": "saccharomyces cerevisiae" 와 일치하는 문서 10,000개가 포함되어 있고 해당 문서 중 "stock": 60 와 일치하는 문서가 100개 있는 경우 쿼리는 10,000개의 키를 검사합니다. IXSCAN 단계에서 쿼리는 stock 필드를 기준으로 이러한 키를 필터링하고 다음 단계에 100개의 결과만 반환합니다.
MongoDB의 인덱싱 전략은 정확히 일치하는 필드를 특정 순서로 배열할 필요가 없습니다. 그러나 쿼리가 정렬 사양 앞에 오거나 겹치는 인덱스 접두사에 동등성 조건을 지정하지 않으면 작업에서 인덱스를 효율적으로 사용하지 않습니다. 자세한 내용은 인덱스의 정렬 및 접두사가 없는 하위 집합을 참조하세요.
MongoDB는 복합 인덱스를 사용하여 다음 필드 조합에 대한 쿼리를 지원할 수 없습니다 .
locationstocklocation개인정보 정책에stock
item 필드가 없으면 앞의 필드 조합 중 어느 것도 접두사 인덱스에 해당하지 않습니다.
팁
중복 인덱스 제거
복합 인덱스와 접두사에 인덱스가 모두 있는 컬렉션(예시: { a: 1, b: 1 } 및 { a: 1 })에서 어느 인덱스에도 희소(sparse) 또는 고유(unique) 제약 조건이 없는 경우 접두사({ a: 1 })에 대한 인덱스를 제거할 수 있습니다. MongoDB는 접두사 인덱스를 사용했던 모든 상황에서 복합 인덱스를 사용합니다.
희소 복합 인덱스
복합 인덱스에는 다양한 유형의 희소 인덱스가 포함될 수 있습니다. 인덱스 유형의 조합이 복합 인덱스가 문서를 어떻게 매칭하는지 결정합니다.
이 표에는 다양한 유형의 희소 인덱스가 포함된 복합 인덱스의 동작이 요약되어 있습니다.
복합 인덱스 구성 요소 | 컴파운드 인덱스 동작 |
|---|---|
Ascending indexes Descending indexes | 적어도 하나의 키에 대한 값을 포함하는 문서만 인덱싱합니다. |
문서에 | |
|
자세히 알아보기
효율적인 복합 인덱스를 만드는 방법을 학습하려면 ESR(동등성, 정렬, 범위) 가이드라인을 참조하세요.