개요
이 가이드 에서는 코틀린 동기 (Kotlin Sync) 운전자 사용하여 컬렉션 에서MongoDB Search 쿼리를 실행 방법을 학습 수 있습니다. MongoDB Search를 사용하면 MongoDB Atlas 에서 호스팅되는 컬렉션에서 전체 텍스트 검색을 수행할 수 있습니다. MongoDB Search 인덱스는 검색 동작과 인덱스 할 필드를 지정합니다.
샘플 데이터
이 가이드 의 예제에서는 Atlas 샘플 데이터 세트의 sample_mflix 데이터베이스 에 있는 movies 컬렉션 사용합니다. 무료 MongoDB Atlas cluster 생성하고 샘플 데이터 세트를 로드하는 방법을 학습하려면 Atlas 시작하기 가이드를 참조하세요. 집계 작업 및 빌더 에 대해 자세히 학습 애그리게이션 작업 가이드 참조하세요.
MongoDB 검색 쿼리 실행
이 섹션에서는 컬렉션 에서 MongoDB Search 쿼리 실행 위한 집계 파이프라인 만드는 방법을 보여 줍니다. Aggregates.search() 빌더 메서드를 사용하여 검색 기준을 지정하는 $search 파이프라인 단계를 만들 수 있습니다. 그런 다음 aggregate() 메서드를 호출하고 파이프라인 매개 변수로 전달합니다.
참고
MongoDB Atlas v4.2 이상에서만 사용 가능
이 집계 파이프라인 연산자4.2 MongoDB Search 인덱스 가 적용되는 v 이상을 실행 MongoDB Atlas 클러스터에 호스팅되는 컬렉션에만 사용할 수 있습니다. 이 연산자 의 필수 설정 및 기능에 대한 자세히 보기 MongoDB Search 설명서를 참조하세요.
MongoDB Search 쿼리 실행 전에 컬렉션 에 MongoDB Search 인덱스 만들어야 합니다. 프로그래밍 방식으로 MongoDB Search 인덱스 만드는 방법을 학습 인덱스 가이드 의 검색 인덱스 만들기 섹션을 참조하세요.
MongoDB 검색 예시
이 예시 다음 조치를 수행하여 MongoDB Search 쿼리 실행합니다.
Aggregates.search()빌더 메서드를 사용하여$search스테이지를 구성하고, 드라이버에게title필드에"Alabama"단어가 포함된 문서를 쿼리하도록 지시합니다.Aggregates.project()빌더 메서드를 사용하여$project단계를 구성하고, 쿼리 결과에title필드 포함하도록 운전자 에 지시합니다.파이프라인 단계를
aggregate()메서드에 전달하고 결과를 출력합니다.
val pipeline: List<Bson> = listOf( search(SearchOperator.text( fieldPath("title"), "Alabama")), project(Projections.include("title")) ) val results = collection.aggregate(pipeline) results.forEach { doc -> println(doc.toJson()) }
{"_id": {"$oid": "..."}, "title": "Alabama Moon"} {"_id": {"$oid": "..."}, "title": "Crazy in Alabama"} {"_id": {"$oid": "..."}, "title": "Sweet Home Alabama"}
MongoDB 검색 메타데이터
searchMeta() 메서드를 사용하여 Atlas 전체 텍스트 검색 결과에서 메타데이터 만 반환하는 $searchMeta 파이프라인 단계를 만듭니다.
팁
MongoDB Atlas v4.4.11 이상에서만 사용 가능
이 집계 파이프라인 연산자는 v4.4.11 이상을 실행하는 MongoDB Atlas 클러스터에서만 사용할 수 있습니다.
다음 예시 MongoDB Search 집계 단계의 near 메타데이터 보여줍니다.
searchMeta( SearchOperator.near(2010, 1, fieldPath("year")) )
추가 정보
MongoDB Search에 대해 자세히 학습 Atlas 설명서에서 MongoDB Search를 참조하세요.
API 문서
이 가이드 에 언급된 메서드에 학습 보려면 다음 API 설명서를 참조하세요.