Docs Menu
Docs Home
/ / /
Scala
/

복합 인덱스

이 페이지의 내용

  • 개요
  • 샘플 데이터
  • 복합 색인 만들기
  • 추가 정보
  • API 문서

복합 인덱스 는 컬렉션 문서 내의 여러 필드에 대한 참조를 보유하여 쿼리 및 정렬 성능을 향상시킵니다.

복합 인덱스 생성할 때는 다음 세부 정보를 지정해야 합니다.

  • 인덱스 를 생성할 필드

  • 각 필드 의 정렬 순서(오름차순 또는 내림차순)

이 가이드 의 예제에서는 movies sample_mflix Atlas 샘플 데이터 세트의 데이터베이스 에 있는 컬렉션 사용합니다. 스칼라 애플리케이션 에서 이 컬렉션 액세스 하려면 MongoClient Atlas cluster 에 연결하는 를 만들고 및 변수에 다음 값을 할당합니다.database collection

val database: MongoDatabase = mongoClient.getDatabase("sample_mflix")
val collection: MongoCollection[Document] = database.getCollection("movies")

무료 MongoDB Atlas cluster 를 생성하고 샘플 데이터 세트를 로드하는 방법을 학습 보려면 Atlas 시작하기 가이드 를 참조하세요.

이 가이드 의 예제를 실행 하려면 파일 에 다음 가져오기 문을 포함해야 합니다.

import org.mongodb.scala._
import org.mongodb.scala.model.Indexes
import org.mongodb.scala.model.IndexOptions._
import org.mongodb.scala.model.Filters._
import scala.concurrent.Await
import scala.concurrent.duration._
import scala.util.{Failure, Success}
import java.util.concurrent.TimeUnit

createIndex() 메서드를 사용하여 복합 인덱스 만듭니다. 다음 예시 runtime 필드 에 내림차순으로 인덱스를 생성하고 year 필드 에 오름차순으로 인덱스 생성합니다.

val index = Indexes.compoundIndex(Indexes.descending("runtime"),
Indexes.ascending("year"))
val observable = collection.createIndex(index)
Await.result(observable.toFuture(), Duration(10, TimeUnit.SECONDS))

listIndexes() 메서드를 사용하여 인덱스 생성되었는지 확인할 수 있습니다. 다음 출력과 같이 목록에 runtimeyear 에 대한 인덱스 표시되어야 합니다.

collection.listIndexes().subscribe((doc: Document) => println(doc.toJson()),
(e: Throwable) => println(s"There was an error: $e"))
{"v": 2, "key": {"runtime": -1, "year": 1}, "name": "runtime_-1_year_1"}

다음은 runtimeyear 필드에 생성된 인덱스 가 적용되는 쿼리 의 예시 입니다.

val filter = and(gt("runtime", 80), gt("year", 1999))
collection.find(filter).first().subscribe((doc: Document) => println(doc.toJson()),
(e: Throwable) => println(s"There was an error: $e"))
{"_id":...,"runtime": 98,...,"title": "In the Mood for Love",...,"year": 2000,...}

복합 인덱스에 학습 보려면 MongoDB Server 매뉴얼의 복합 인덱스 를 참조하세요.

인덱스를 관리하는 방법을 보여주는 실행 가능한 예제를 보려면 인덱스를 사용하여 쿼리 최적화를 참조하세요.

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

돌아가기

단일 필드