Docs Menu
Docs Home
/ / /
Kotlin 코루틴
/ / /

대량 작업

이 페이지의 내용

  • 개요
  • 컬렉션 대량 쓰기
  • 삽입 작업
  • 대체 작업
  • 업데이트 작업
  • 삭제 작업
  • 실행 순서
  • 클라이언트 대량 쓰기
  • 삽입 작업
  • 대체 작업
  • 대량 쓰기 옵션
  • 요약
  • MongoCollection.bulkWrite()
  • MongoClient.bulkWrite()

이 가이드 에서는 코틀린 (Kotlin) 운전자 에서 대량 작업을 사용하는 방법을 학습 수 있습니다.

단일 생성, 교체, 업데이트 또는 삭제 작업을 수행하려면 해당 메서드를 사용할 수 있습니다. 예시 를 들어 insertOne()replaceOne() 메서드를 사용하여 문서 하나를 삽입하고 문서 하나를 바꿀 수 있습니다. 이러한 메서드를 사용하면 클라이언트 각 작업에 대해 데이터베이스 를 한 번 호출합니다.

대량 쓰기 (write) 작업을 사용하면 더 적은 수의 데이터베이스 호출로 여러 쓰기 (write) 작업을 수행할 수 있습니다. 다음 수준에서 대량 쓰기 (write) 작업을 수행할 수 있습니다.

  • 컬렉션:MongoCollection.bulkWrite() 메서드를 사용하여 단일 컬렉션 에 대해 대량 쓰기 (write) 작업을 수행할 수 있습니다. 이 메서드에서는 각 종류의 쓰기 (write) 작업에 하나 이상의 데이터베이스 호출이 필요합니다. 예시 를 들어 는MongoCollection.bulkWrite() 여러 업데이트 작업을 한 번의 호출에 처리하지만 삽입 작업과 바꾸기 작업에 대해 데이터베이스 두 번 개별적으로 호출합니다.

  • 클라이언트:애플리케이션 MongoDB 서버 버전 이상에 연결되는 경우 메서드를 8.0 사용하여 동일한 클러스터 의 MongoClient.bulkWrite() 여러 컬렉션 및 데이터베이스에서 대량 쓰기 (write) 작업을 수행할 수 있습니다. 이 메서드는 한 번의 데이터베이스 호출로 모든 쓰기 (write) 작업을 수행합니다.

대량 쓰기 (write) 작업에는 하나 이상의 쓰기 (write) 작업이 포함됩니다. 컬렉션 수준에서 대량 쓰기 (write) 작업을 수행하려면 WriteModel 문서의 ListMongoCollection.bulkWrite() 메서드에 전달합니다. WriteModel 는 쓰기 (write) 작업을 나타내는 모델입니다.

MongoCollection.bulkWrite() 메서드는 별도의 데이터베이스 호출에서 각 종류의 쓰기 (write) 작업을 수행합니다. 예시 를 들어 DeleteOneModel, DeleteManyModelReplaceOneModel 객체를 메서드에 전달하면 삭제 작업에 대한 호출과 바꾸기 작업에 대한 호출이라는 두 가지 호출을 수행합니다.

참고

클라이언트 작업을 별도의 데이터베이스 호출로 분할할 때 대량 쓰기 (write) 작업의 순서가 지정되지 않은 경우 효율성 위해 작업 순서를 변경할 수 있습니다. 작업 실행 순서에 대해 자세히 학습 실행 순서 섹션을 참조하세요.

다음 섹션에서는 각 WriteModel 문서를 만들고 사용하는 방법을 보여 줍니다. 각 섹션의 예에서는 people 컬렉션의 다음 문서를 사용합니다.

{ "_id": 1, "name": "Karen Sandoval", "age": 31 }
{ "_id": 2, "name": "William Chin", "age": 54 }
{ "_id": 8, "name": "Shayla Ray", "age": 20 }

이 데이터는 다음 코틀린 (Kotlin) 데이터 클래스에 의해 모델링됩니다.

data class Person(
@BsonId val id: Int,
val name: String,
val age: Int? = null,
val location: String? = null
)

이 섹션에 언급된 메서드 및 클래스에 대한 자세한 내용은 다음 API 문서를 참조하세요.

삽입 작업을 수행하려면 삽입하려는 문서를 지정하는 InsertOneModel을 만듭니다. 여러 문서를 삽입하려면 삽입하려는 각 문서에 대해 InsertOneModel을 만듭니다.

다음 예에서는 사람을 설명하는 두 문서에 대해 InsertOneModel을 만듭니다.

val juneDoc = InsertOneModel(Person(3, "June Carrie", 17))
val kevinDoc = InsertOneModel(Person(4, "Kevin Moss", 22))

중요

bulkWrite() 작업을 수행할 때 InsertOneModel 은 collection에 이미 존재하는 _id 가 포함된 문서를 삽입할 수 없습니다. 이 경우 드라이버는 MongoBulkWriteException 을 발생시킵니다.

다음 예에서는 _id 값이 13 인 두 문서를 삽입하려고 시도합니다. collection에 1_id 이 있는 문서가 이미 있으므로 이 작업을 수행하면 오류가 발생합니다.

try {
val bulkOperations = listOf(
(InsertOneModel(Person(1, "James Smith", 13))),
(InsertOneModel(Person(3, "Colin Samuels")))
)
val bulkWrite = collection.bulkWrite(bulkOperations)
} catch (e: MongoBulkWriteException) {
println("A MongoBulkWriteException occurred with the following message: " + e.message)
}
A MongoBulkWriteException occurred with the following message:
Bulk write operation error on server sample-shard-00-02.pw0q4.mongodb.net:27017.
Write errors: [BulkWriteError{index=0, code=11000, message='E11000 duplicate key
error collection: crudOps.bulkWrite index: _id_ dup key: { _id: 1 }', details={}}].

드라이버가 3 _id 인 문서를 삽입하지 않은 이유에 대해 알아보려면 실행 순서 섹션을 참조하세요.

이 섹션에 언급된 메서드 및 클래스에 대한 자세한 내용은 InsertOneModel API 설명서를 참조하세요.

대체 작업을 수행하려면 대체하려는 문서와 대체 문서에 대한 쿼리 필터를 지정하는 ReplaceOneModel 을 만듭니다.

중요

bulkWrite() 를 수행할 때 ReplaceOneModel 은 collection의 고유 인덱스 제약 조건을 위반하는 변경을 수행할 수 없습니다. 또한 쿼리 필터와 일치하는 항목이 없는 경우 모델은 바꾸기 작업을 수행하지 않습니다.

다음 예에서는 _id1 인 문서를 추가 location 필드가 포함된 문서로 대체하기 위해 ReplaceOneModel 을 만듭니다.

val filter = Filters.eq("_id", 1)
val insert = Person(1, "Celine Stork", location = "San Diego, CA")
val doc = ReplaceOneModel(filter, insert)

여러 문서가 ReplaceOneModel 인스턴스 에 지정된 쿼리 필터하다 와 일치하는 경우 작업은 첫 번째 결과를 대체합니다. 다음 코드와 같이 ReplaceOptions 인스턴스 에서 정렬을 지정하여 운전자 바꾸기 작업을 수행하기 전에 일치하는 문서에 순서를 적용 할 수 있습니다.

val opts = ReplaceOptions().sort(Sorts.ascending("_id"))

이 섹션에 언급된 메서드 및 클래스에 대한 자세한 내용은 다음 API 리소스를 참조하세요.

업데이트 작업을 수행하려면 쿼리 필터와 업데이트 문서를 지정하는 UpdateOneModel 또는 UpdateManyModel 를 만듭니다.

UpdateOneModel은 쿼리 필터와 일치하는 첫 번째 문서를 업데이트하고, UpdateManyModel은 쿼리 필터와 일치하는 모든 문서를 업데이트합니다.

중요

bulkWrite() 를 수행할 때 UpdateOneModelUpdateManyModel 유형은 collection의 고유 인덱스 제약 조건을 위반하는 변경을 수행할 수 없습니다. 또한 쿼리 필터와 일치하는 항목이 없는 경우 모델은 업데이트 작업을 수행하지 않습니다.

다음 예시에서는 _id2 인 문서에서 age 필드를 1 만큼 증가시키는 UpdateOneModel 을 만듭니다.

val filter = Filters.eq("_id", 2)
val update = Updates.inc(Person::age.name, 1)
val doc = UpdateOneModel<Person>(filter, update)

여러 문서가 UpdateOneModel 인스턴스 에 지정된 쿼리 필터하다 와 일치하는 경우 작업은 첫 번째 결과를 업데이트합니다. 다음 코드와 같이 UpdateOptions 인스턴스 에서 정렬을 지정하여 운전자 업데이트 작업을 수행하기 전에 일치하는 문서에 순서를 적용 수 있습니다.

val opts = UpdateOptions().sort(Sorts.ascending("_id"))

이 섹션에 언급된 메서드 및 클래스에 대한 자세한 내용은 다음 API 리소스를 참조하세요.

삭제 작업을 수행하려면 삭제하려는 문서에 대한 쿼리 필터를 지정하는 DeleteOneModel 또는 DeleteManyModel 를 만듭니다.

DeleteOneModel은 쿼리 필터와 일치하는 첫 번째 문서를 삭제하고 DeleteManyModel은 쿼리 필터와 일치하는 모든 문서를 삭제합니다.

중요

bulkWrite() 수행 시 DeleteOneModelDeleteManyModel 유형은 쿼리 필터와 일치하는 항목이 없는 경우 문서를 삭제하지 않습니다.

다음 예에서는 _id1 인 문서를 삭제하기 위해 DeleteOneModel 을 만들고 age 값이 30 보다 작은 문서를 삭제하기 위해 DeleteManyModel 을 만듭니다.

val deleteId1 = DeleteOneModel<Person>(Filters.eq("_id", 1))
val deleteAgeLt30 = DeleteManyModel<Person>(Filters.lt(Person::age.name, 30))

이 섹션에 언급된 메서드 및 클래스에 대한 자세한 내용은 다음 API 문서를 참조하세요.

bulkWrite() 메서드는 선택적 BulkWriteOptions 을 두 번째 매개 변수로 허용하여 대량 작업을 순서가 지정된 작업으로 실행할지, 순서가 지정되지 않은 상태로 실행할지 여부를 지정합니다.

기본적으로 bulkWrite() 메서드는 대량 작업을 순서대로 실행합니다. 즉, 오류가 발생할 때까지 목록에 추가한 순서대로 작업이 실행됩니다.

다음 예에서는 아래의 대량 작업을 수행합니다.

  • name 이(가) "Zaynab Omar" 이고 age 이(가) 37인 문서에 대한 삽입 작업입니다.

  • _id1 인 문서를 location 필드가 포함된 새 문서로 대체하는 작업

  • _id6 인 문서에 대한 업데이트 작업을 수행하여 name 필드를 변경합니다.

  • age 값이 50보다 큰 모든 문서에 대한 삭제 작업

val insertMdl = InsertOneModel(Person(6, "Zaynab Omar", 37))
val replaceMdl = ReplaceOneModel(
Filters.eq("_id", 1),
Person(1, "Sandy Kane", location = "Helena, MT")
)
val updateMdl = UpdateOneModel<Person>(
Filters.eq("_id", 6),
Updates.set(Person::name.name, "Zaynab Hassan")
)
val deleteMdl = DeleteManyModel<Person>(Filters.gt(Person::age.name, 50))
val bulkOperations = listOf(
insertMdl,
replaceMdl,
updateMdl,
deleteMdl
)
val result = collection.bulkWrite(bulkOperations)

이 예시가 실행된 후에는 컬렉션에 다음 문서가 포함됩니다.

{ "_id": 1, "name": "Sandy Kane", "location": "Helena, MT" }
{ "_id": 8, "name": "Shayla Ray", "age": 20 }
{ "_id": 6, "name": "Zaynab Hassan", "age": 37 }

BulkWriteOptions 객체의 ordered() 메서드에 false 을 전달하여 순서에 상관없이 대량 작업을 실행할 수도 있습니다. 즉, 오류와 관계없이 모든 쓰기 작업이 실행됩니다. 오류가 발생하면 드라이버는 마지막에 오류를 보고합니다.

다음 코드는 실행 순서 없이 대량 작업을 실행하는 방법을 보여줍니다.

val options = BulkWriteOptions().ordered(false)
val unorderedResult = collection.bulkWrite(bulkOperations, options)

참고

순서가 지정되지 않은 대량 작업은 실행 순서를 보장하지 않습니다. 순서는 런타임을 최적화하기 위해 나열한 방식과 다를 수 있습니다.

앞의 예에서 bulkWrite() 메서드가 업데이트 작업 후에 삽입 작업을 수행한 경우 해당 시점에 문서가 존재하지 않았으므로 업데이트 작업은 변경 사항을 생성하지 않습니다. 그러면 collection에 다음 문서가 포함됩니다.

{ "_id": 1, "name": "Sandy Kane", "location": "Helena, MT" }
{ "_id": 8, "name": "Shayla Ray", "age": 20 }
{ "_id": 6, "name": "Zaynab Omar", "age": 37 }

이 섹션에 언급된 메서드 및 클래스에 대한 자세한 내용은 다음 API 문서를 참조하세요.

MongoDB 서버 8.0 이상을 실행 배포서버 에 연결할 때 MongoClient.bulkWrite() 메서드를 사용하여 동일한 클러스터 의 여러 데이터베이스 및 컬렉션에 쓰기 (write) 수 있습니다. MongoClient.bulkWrite() 메서드는 한 번의 호출로 모든 쓰기 (write) 작업을 수행합니다.

MongoClient.bulkWrite() 메서드는 ClientNamespacedWriteModel 인스턴스 목록을 사용하여 다양한 쓰기 (write) 작업을 나타냅니다. 인스턴스 메서드를 사용하여 ClientNamespacedWriteModel 인터페이스의 인스턴스를 구성할 수 있습니다. 예시 를 들어 ClientNamespacedInsertOneModel 의 인스턴스 하나의 문서 삽입하는 작업을 나타내며 ClientNamespacedWriteModel.insertOne() 메서드를 사용하여 이 모델을 만들 수 있습니다.

참고

대량 쓰기 오류

쓰기 (write) 작업 중 하나라도 실패하면 운전자 ClientBulkWriteException 를 발생시키고 더 이상 개별 작업을 수행하지 않습니다. ClientBulkWriteException 에는 개별 장애에 대한 세부 정보를 제공하는 ClientBulkWriteException.getWriteErrors() 메서드를 사용하여 액세스할 수 있는 BulkWriteError 가 포함되어 있습니다.

모델과 해당 인스턴스 메서드는 아래 표에 설명되어 있습니다.

모델
인스턴스 메서드
설명
매개변수

ClientNamespacedInsertOneModel

insertOne()

namespace에 문서 삽입할 모델을 만듭니다.

namespace: 쓰기 (write) 데이터베이스 및 컬렉션

document: 삽입할 문서

ClientNamespacedUpdateOneModel

updateOne()

filter와 일치하는 namespace 의 첫 번째 문서 업데이트 모델을 만듭니다.

namespace: 쓰기 (write) 데이터베이스 및 컬렉션

filter: 업데이트 할 문서 선택하는 필터

update: 일치하는 문서 에 적용 업데이트

updatePipeline: 일치하는 문서 에 적용 파이프라인 업데이트

options: (선택 사항) 문서 업데이트 시 적용 옵션

update 또는 updatePipeline 매개변수 값을 전달해야 합니다.

ClientNamespacedUpdateManyModel

updateMany()

filter와 일치하는 namespace 의 모든 문서를 업데이트 모델을 만듭니다.

namespace: 쓰기 (write) 데이터베이스 및 컬렉션

filter: 업데이트 할 문서를 선택하는 필터

update: 일치하는 문서에 적용 업데이트

updatePipeline: 일치하는 문서에 적용 파이프라인 업데이트

options: (선택 사항) 문서 업데이트 시 적용 옵션

update 또는 updatePipeline 매개변수 값을 전달해야 합니다.

ClientNamespacedReplaceOneModel

replaceOne()

filter와 일치하는 namespace 의 첫 번째 문서 대체할 모델을 만듭니다.

namespace: 쓰기 (write) 데이터베이스 및 컬렉션

filter: 대체할 문서 선택하는 필터

replacement: 대체 문서

options: (선택 사항) 문서를 교체할 때 적용 옵션

ClientNamespacedDeleteOneModel

deleteOne()

namespace 에서 filter과 일치하는 첫 번째 문서 삭제 하는 모델을 생성합니다.

namespace: 쓰기 (write) 데이터베이스 및 컬렉션

filter: 삭제 문서 선택하는 필터

option: (선택 사항) 문서 삭제할 때 적용 할 옵션

ClientNamespacedDeleteManyModel

deleteMany()

filter와(과) 일치하는 namespace 의 모든 문서를 삭제 하는 모델을 생성합니다.

namespace: 쓰기 (write) 데이터베이스 및 컬렉션

filter: 삭제 문서를 선택하는 필터

option: (선택 사항) 문서를 삭제할 때 적용 할 옵션

다음 섹션에서는 클라이언트 bulkWrite() 메서드를 사용하는 방법의 예를 제공합니다. 샘플 데이터는 다음 코틀린 (Kotlin) 데이터 클래스로 모델링됩니다.

data class Person(
@BsonId val id: Int,
val name: String,
)
data class Object(
@BsonId val id: Int,
val type: String,
)

이 섹션에 언급된 메서드 및 클래스에 학습 보려면 다음 API 설명서를 참조하세요.

이 예시 bulkWrite() 메서드를 사용하여 두 개의 문서를 삽입하는 방법을 보여 줍니다. 한 문서 sample_db.people 컬렉션 에 삽입되고 다른 문서 sample_db.objects 컬렉션 에 삽입됩니다. MongoNamespace 인스턴스 각 쓰기 (write) 작업이 적용되는 데이터베이스와 컬렉션을 정의합니다.

val docsToInsert = mutableListOf<ClientNamespacedWriteModel>()
docsToInsert.add(ClientNamespacedWriteModel
.insertOne(
MongoNamespace("sample_db", "people"),
Person(2, "Julia Smith")
)
)
docsToInsert.add(ClientNamespacedWriteModel
.insertOne(
MongoNamespace("sample_db", "objects"),
Object(2, "washing machine")
)
)
val clientBulkResult = client.bulkWrite(docsToInsert)

다음 예시 bulkWrite() 메서드를 사용하여 sample_db.peoplesample_db.things 컬렉션의 기존 문서를 바꾸는 방법을 보여 줍니다.

val docsReplacements = mutableListOf<ClientNamespacedWriteModel>()
docsReplacements.add(ClientNamespacedWriteModel
.replaceOne(
MongoNamespace("sample_db", "people"),
Filters.eq(Person::id.name, 1),
Person(1, "Frederic Hilbert")
)
)
docsReplacements.add(ClientNamespacedWriteModel
.replaceOne(
MongoNamespace("sample_db", "objects"),
Filters.eq(Object::id.name, 1),
Object(1, "ironing board")
)
)
val clientBulkResult = client.bulkWrite(docsReplacements)

이 예시 성공적으로 실행되면 people 컬렉션 에서 _id 값이 1 인 문서 새 문서 로 대체됩니다. things 컬렉션 의 _id 값이 1 인 문서 새 문서 로 대체됩니다.

ClientBulkWriteOptions 의 인스턴스 bulkWrite() 메서드에 전달하여 대량 쓰기 (write) 작업을 실행 때 옵션을 지정할 수 있습니다.

기본값 으로 대량 작업의 개별 작업은 오류가 발생하거나 성공적으로 실행될 때까지 지정한 순서대로 실행됩니다. 그러나 ClientBulkWriteOptions 인터페이스의 ordered() 메서드에 false 을 전달하여 순서가 지정되지 않은 방식으로 쓰기 (write) 작업을 수행할 수 있습니다. 순서가 지정되지 않은 옵션을 사용하는 경우 오류가 발생하는 작업은 bulkWrite() 메서드 호출에서 다른 쓰기 (write) 작업의 실행을 방해하지 않습니다.

다음 코드는 ClientBulkWriteOptions 인스턴스 에 ordered() 메서드를 설정하고 대량 쓰기 (write) 작업을 수행하여 여러 문서를 삽입합니다.

val namespace = MongoNamespace("sample_db", "people")
val options = ClientBulkWriteOptions
.clientBulkWriteOptions()
.ordered(false)
val bulkOperations = listOf(
ClientNamespacedWriteModel.insertOne(
namespace,
Person(2, "Rudra Suraj")
),
// Causes duplicate key error
ClientNamespacedWriteModel.insertOne(
namespace,
Person(2, "Wendy Zhang")
),
ClientNamespacedWriteModel.insertOne(
namespace,
Person(4, "Mario Bianchi")
)
)
val result = client.bulkWrite(bulkOperations, options)

중복 키가 있는 문서 삽입하는 쓰기 (write) 작업으로 인해 오류가 발생하더라도 쓰기 (write) 작업이 순서가 지정되지 않았으므로 다른 작업은 실행됩니다.

이 섹션에 언급된 메서드 및 클래스에 학습 보려면 다음 API 설명서를 참조하세요.

대량 작업을 수행하려면 WriteModel 인스턴스 목록을 만들어 bulkWrite() 메서드에 전달합니다.

InsertOneModel, ReplaceOneModel, UpdateOneModel, UpdateManyModel, DeleteOneModel, DeleteManyModel 등 6 개의 다양한 WriteModel 하위 유형이 있습니다.

bulkWrite() 메서드를 실행하는 방법에는 두 가지가 있습니다.

  • 순서 지정됨 - 오류가 발생할 때까지 대량 작업을 순서대로 수행

  • 순서 지정되지 않음 - 순서에 관계없이 모든 대량 작업을 수행하고 마지막에 오류를 보고

컬렉션 bulkWrite 명령에 대해 자세히 학습 db를 참조하세요. 컬렉션.bulkWrite() 메서드 참조는 MongoDB 서버 매뉴얼에서 확인 가능합니다.

MongoDB 서버 버전 8.0 이상을 실행 배포서버 에 연결할 때 MongoClient.bulkWrite() 메서드를 사용하여 여러 데이터베이스 및 컬렉션에서 한 번에 대량 작업을 수행할 수 있습니다.

클라이언트 일괄 작업을 수행하려면 이 메서드에 전달할 ClientNamespacedWriteModel 인스턴스 목록을 만듭니다.

쓰기 (write) 작업을 나타내는 데 사용되는 ClientNamespacedWriteModel 의 6가지 하위 유형이 있습니다. 이러한 쓰기 (write) 모델을 구성하려면 해당 ClientNamespacedWriteModel 메서드 insertOne(), updateOne(), updateMany(), replaceOne(), deleteOne()deleteMany()를 사용할 수 있습니다. 이 메서드는 쓰기 (write) 데이터베이스 와 컬렉션 정의하는 MongoNamespace 객체 사용합니다.

MongoClient.bulkWrite() 메서드는 ClientBulkWriteOptions 객체 사용하여 명령이 실행되는 방식에 대한 다양한 옵션을 지정할 수도 있습니다.

클라이언트 bulkWrite 명령에 대해 자세히 학습 MongoDB 서버 매뉴얼에서 bulkWrite() 메서드 참조를 참조하세요.

돌아가기

한 번의 작업으로 삽입 또는 업데이트