Docs Menu
Docs Home
/ / /
Scala
/

지리 공간적 Atlas Search

이 페이지의 내용

  • 전제 조건
  • MongoDB 배포에 연결하기
  • 2차원 구체 인덱스 만들기
  • GeoJSON 점 근처 위치 쿼리

지리 공간적 쿼리를 지원 하기 위해 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 deployment에 연결한 다음 MongoDatabaseMongoCollection 인스턴스를 선언하고 정의합니다.

다음 코드는 포트 27017localhost 에서 실행되는 독립형 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에 연결 튜토리얼을 참조하세요.

2dsphere 인덱스를 생성하려면 Indexes.geo2dsphere() 헬퍼를 사용하여 2dsphere 인덱스에 대한 사양을 생성합니다. 인덱스를 생성하려면 MongoCollection.createIndex() 메서드에 사양을 전달합니다.

다음 예시에서는 컬렉션의 "contact.location" 필드에 2dsphere 인덱스를 생성합니다.

collection.createIndex(Indexes.geo2dsphere("contact.location")).printResults()

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()

돌아가기

텍스트 검색