Docs Menu
Docs Home
/ / /
Scala
/

확장 JSON

이 페이지의 내용

  • 개요
  • JSON 작성
  • JSON 읽기
  • JSON 직접 읽기 및 쓰기
  • CustomSettings로 JSON 읽기 및 쓰기

Scala 운전자 는 확장 으로 표시되는 BSON 문서의 읽기 및 쓰기를 MongoDB JSON지원합니다. 다음 변형이 모두 지원됩니다.

  • 엄격 모드: JSON RFC 를 준수하는 BSON types 표현입니다. 이는 mongoexport가 생성하고 mongoimport가 사용하는 형식입니다.

  • shell 모드: 이 JSON MongoDB shell 구문 분석할 수 있는 의 상위 집합입니다.

또한 Document 유형은 이러한 목적으로 두 가지 편의 메서드 세트를 제공합니다.

  • Document.toJson(): Document 인스턴스 를 JSON string로 변환하는 오버로드된 메서드 설정하다 입니다.

  • Document(<json>): JSON string 을 Document 인스턴스 로 변환하는 오버로드된 정적 팩토리 메서드 설정하다 입니다.

운전자 를 사용하여 mongoexport와 유사한 도구를 구현하는 작업 을 고려합니다.

val fileName = // initialize to the path of the file to write to
val collection = // initialize the collection from which you want to query
val writer: PrintWriter = new PrintWriter(fileName)
collection.find().subscribe(
(doc: Document) => output.write(s"${doc.toJson}\r\n"),
(t: Throwable) => // handle failure,
() => output.close())

Document.toJson() 메서드는 줄 바꿈이나 들여쓰기 없이 엄격 모드 로 쓰는 기본값 설정으로 JsonWriter 의 인스턴스 를 구성합니다.

toJson() 의 오버로드 중 하나를 사용하여 이 기본값 동작을 재정의할 수 있습니다. 예를 예시, 에 복사하여 JSON string 붙여넣을 수 있는 을 작성하는 작업 을 생각해 MongoDB shell 보겠습니다.

import java.text.SimpleDateFormat
val fmt = new SimpleDateFormat("dd/MM/yy")
val first = fmt.parse("01/01/2014")
val second = fmt.parse("01/01/2015")
val doc = Document("startDate" -> Document("$gt" -> first, "$lt" -> second))
println(doc.toJson(new JsonWriterSettings(JsonMode.SHELL)))

이 코드 스니펫은 MongoDB shell과 호환되는 JSON 을 출력한 다음 shell 에 붙여넣을 수 있습니다.

{ "startDate" : { "$gt" : ISODate("2014-01-01T05:00:00.000Z"), "$lt" : ISODate("2015-01-01T05:00:00.000Z") } }

드라이버를 사용하여 mongoimport와 유사한 도구를 구현하는 작업을 고려하세요.

import scala.io.Source
val fileName = // initialize to the path of the file to read from
val collection = // initialize the collection from which you want to import to
try {
for (json <- Source.fromFile(fileName).getLines()) {
collection.insertOne(Document(json)).head()
}
} catch {
case ex: Exception => println("Bummer, an exception happened.")
}

Document(<json>) 컴패니언 헬퍼 메서드는 지정된 string 을 사용하여 JsonReader 인스턴스 를 구성하고 이에 상응하는 Document 인스턴스 의 인스턴스 를 반환합니다. JsonReader JSON 는 에서 플레이버를 자동으로 string 감지하므로 지정할 필요가 없습니다.

문서 가 필요하지 않고 JSON 만 처리하려는 경우 JsonObject 를 사용하여 JSON 을 직접 읽고 쓰기 (write) 수 있습니다. JsonObject 은 생성자에서 String 를 취하고 getJson() 메서드에서 String 을 반환하는 래퍼 클래스입니다. JSON 을 직접 읽고 쓰는 것이 Document 을 먼저 구성한 다음 toJson() 을 호출하는 것보다 더 효율적이며 Document#parse() 을 호출하는 것보다 더 효율적입니다.

JSONJsonObjectCodec 읽기/쓰기를 담당하는 코덱은 기본값 레지스트리의 일부이므로 이 작업을 수행하는 것은 매우 간단하며 다음 예시 통해 확인할 수 있습니다.

val database: MongoDatabase = mongoClient.getDatabase("mydb")
val collection: MongoCollection[JsonObject] = database.getCollection("test")
collection.insertOne(new JsonObject("{hello: 1}")).printResults()
val jsonObject: SingleObservable[JsonObject] = collection.find.first()

코덱을 직접 구성한 다음 레지스트리를 만들어 JsonObjectCodec 에 사용자 지정 JsonWriterSettings 를 제공할 수도 있습니다.

val codecRegistry =
fromRegistries(
fromCodecs(new JsonObjectCodec(JsonWriterSettings
.builder()
.outputMode(JsonMode.EXTENDED)
.build())),
DEFAULT_CODEC_REGISTRY
)
val database: MongoDatabase = mongoClient.getDatabase("mydb").withCodecRegistry(codecRegistry)
val collection: MongoCollection[JsonObject] = database.getCollection("test")
collection.insertOne(new JsonObject("{hello: 1}")).printResults()
val jsonObject: SingleObservable[JsonObject] = collection.find.first()

돌아가기

매크로