지리 공간적 Atlas Search
지리 공간적 쿼리를 지원 하기 위해 MongoDB 는 지리 공간적 인덱스와 지리 공간적 쿼리 연산자를 제공합니다.
지리 공간적 쿼리 수행에 학습 보려면 서버 매뉴얼에서 지리 공간적 쿼리를 참조하세요.
전제 조건
이 가이드의 코드 예제를 실행하려면 다음 구성 요소를 설정해야 합니다.
test.restaurants
문서restaurants.json
자산 에 있는 파일의 문서로 채워진 컬렉션입니다.Github다음 가져오기 문:
import org.mongodb.scala._ import org.mongodb.scala.model.geojson._ import org.mongodb.scala.model.Indexes import org.mongodb.scala.model.Filters
참고
이 가이드 에서는 퀵 스타트 프라이머에 설명된 대로 Observable
암시를 사용합니다.
MongoDB 배포에 연결하기
먼저 MongoDB deployment에 연결한 다음 MongoDatabase
및 MongoCollection
인스턴스를 선언하고 정의합니다.
다음 코드는 포트 27017
의 localhost
에서 실행되는 독립형 MongoDB 배포서버에 연결합니다. 그런 다음 test
데이터베이스를 참조하는 database
변수와 restaurants
컬렉션을 참조하는 collection
변수를 정의합니다.
val mongoClient: MongoClient = MongoClient() val database: MongoDatabase = mongoClient.getDatabase("test") val collection: MongoCollection[Document] = database.getCollection("restaurants")
MongoDB deployment에 연결하는 방법에 대해 자세히 알아보려면 MongoDB에 연결 튜토리얼을 참조하세요.
2차원 구체 인덱스 만들기
2dsphere
인덱스를 생성하려면 Indexes.geo2dsphere()
헬퍼를 사용하여 2dsphere
인덱스에 대한 사양을 생성합니다. 인덱스를 생성하려면 MongoCollection.createIndex()
메서드에 사양을 전달합니다.
다음 예시에서는 컬렉션의 "contact.location"
필드에 2dsphere
인덱스를 생성합니다.
collection.createIndex(Indexes.geo2dsphere("contact.location")).printResults()
GeoJSON 점 근처 위치 쿼리
MongoDB 는 다양한 지리 공간적 쿼리 연산자를 제공합니다. 지리 공간적 쿼리 필터를 쉽게 만들 수 있도록 운전자 는 Filters
클래스와 com.mongodb.client.model.geojson
패키지 제공합니다.
다음 예시 에서는 지정된 GeoJSON Point
인스턴스 에서 최소 1000.0
미터에서 최대 5000.0
미터 떨어져 있는 문서를 가장 가까운 것부터 가장 먼 것 순으로 자동 정렬하여 반환합니다.
val refPoint = Point(Position(-73.9667, 40.78)) collection.find(Filters.near("contact.location", refPoint, 5000.0, 1000.0)).printResults()