AI 에이전트의 경우: 문서 인덱스는 https://www.mongodb.com/ko-kr/docs/llms.txt에서 사용할 수 있으며, 모든 페이지의 마크다운 버전은 어떤 URL 경로에 .md를 추가하여 사용할 수 있습니다.
Docs Menu

대량 쓰기 작업

이 가이드 에서는 Ruby 운전자 사용하여 단일 데이터베이스 호출로 데이터를 여러 번 변경하는 대량 쓰기 (write) 작업을 수행하는 방법을 학습 수 있습니다.

동일한 작업 에 대해 문서를 삽입하고, 문서를 업데이트 , 문서를 삭제 해야 하는 상황을 생각해 보세요. 개별 쓰기 (write) 메서드를 사용하는 경우 각 쓰기 (write) 작업은 데이터베이스 별도로 액세스합니다. 대신 대량 쓰기 (write) 작업을 사용하여 애플리케이션 에서 서버 에 대해 수행하는 호출 수를 최적화할 수 있습니다.

이 가이드 의 예제에서는 Atlas 샘플 데이터 세트sample_restaurants 데이터베이스 에 있는 restaurants 컬렉션 사용합니다. Ruby 애플리케이션 에서 이 컬렉션 에 액세스 하려면 Atlas cluster 에 연결하는 Mongo::Client 객체 만들고 databasecollection 변수에 다음 값을 할당합니다.

database = client.use('sample_restaurants')
collection = database[:restaurants]

무료 MongoDB Atlas 클러스터 생성하고 샘플 데이터 세트를 로드하는 방법을 학습하려면 MongoDB 시작하기 가이드 를 참조하세요.

수행하려는 각 쓰기 (write) 작업에 대해 다음 작업 중 하나를 구현하는 해시를 만듭니다.

  • insert_one

  • update_one

  • update_many

  • replace_one

  • delete_one

  • delete_many

그런 다음 이러한 인스턴스 목록을 bulk_write 메서드에 전달합니다.

다음 섹션에서는 이전 작업의 인스턴스를 만들고 사용하는 방법을 보여줍니다. 대량 작업 수행 섹션에서는 해시 목록을 bulk_write 메서드에 전달하여 대량 작업을 수행하는 방법을 보여 줍니다.

삽입 작업을 수행하려면 insert_one 해시를 만들고 삽입하려는 문서 지정합니다.

다음 예시 insert_one 해시를 생성합니다.

insert_one = { insert_one: { name: 'Steve Rogers Cafe', borough: 'Brooklyn' } }

여러 문서를 삽입하려면 각 문서 에 대해 별도의 insert_one 해시를 만듭니다.

중요

대량 작업을 수행할 때 insert_one 작업은 컬렉션 에 이미 존재하는 _id 이(가) 있는 문서 삽입할 수 없습니다. 이 상황에서 운전자 MongoBulkWriteException를 발생시킵니다.

문서 업데이트 하려면 update_one 해시를 만들고 다음 인수를 전달합니다.

  • 컬렉션 의 문서를 일치시키는 데 사용되는 기준을 지정하는 쿼리 필터하다 입니다.

  • 수행하려는 업데이트 작업입니다. 업데이트 작업에 대한 자세한 내용은 MongoDB Server 매뉴얼의 필드 업데이트 연산자 가이드 참조하세요.

update_one 작업은 쿼리 필터와 일치하는 첫 번째 문서에 대한 업데이트를 지정합니다.

다음 예시 update_one 해시를 생성합니다.

update_one = { update_one:
{
filter: { name: 'Mountain View' },
update: { '$set': { borough: 'Queens' } }
}
}

여러 문서를 업데이트 하려면 update_many 해시를 만들고 update_one 작업과 동일한 인수를 전달합니다. update_many 작업은 쿼리 필터와 일치하는 모든 문서에 대한 업데이트를 지정합니다.

다음 예시 update_many 해시를 생성합니다.

update_many = { update_many:
{
filter: { name: 'Starbucks' },
update: { '$set': { cuisine: 'Cafe' } }
}
}

바꾸기 작업은 지정된 문서 의 모든 필드와 값을 제거하고 사용자가 지정한 새 필드와 값으로 바꿉니다. 바꾸기 작업을 수행하려면 replace_one 해시를 만들고 다음 인수를 전달합니다.

  • 컬렉션 의 문서를 일치시키는 데 사용되는 기준을 지정하는 쿼리 필터하다

  • 삽입할 새 필드와 값을 지정하는 대체 문서

다음 예시 replace_one 해시를 생성합니다.

replace_one = { replace_one:
{
filter: { name: 'Old World Diner' },
replacement: { '$set': { name: 'New Age Luncheonette' } }
}
}

여러 문서를 바꾸려면 각 문서 에 대해 replace_one 해시를 만들어야 합니다.

문서 삭제 하려면 delete_one 해시를 만들고 삭제 하려는 문서 지정하는 쿼리 필터하다 전달합니다. delete_one 작업은 쿼리 필터와 일치하는 첫 번째 문서 만 삭제합니다.

다음 예시 delete_one 해시를 생성합니다.

delete_one = { delete_one: { name: 'Old World Diner' } }

여러 문서를 삭제 하려면 delete_many 해시를 만들고 삭제 하려는 문서 지정하는 쿼리 필터하다 전달합니다. delete_many 작업은 쿼리 필터와 일치하는 모든 문서를 삭제합니다.

다음 예시 delete_many 해시를 생성합니다.

delete_many = { delete_many: { name: 'Starbucks' } }

수행하려는 각 작업에 대한 해시를 정의한 후 이러한 객체 목록을 bulk_write 메서드에 전달합니다. 기본값 으로 이 메서드는 해시 목록에 지정된 순서대로 작업을 실행합니다.

다음 예시 에서는 bulk_write 메서드를 사용하여 여러 쓰기 (write) 작업을 수행합니다.

insert_one = { insert_one: { name: 'Nuovo Ristorante', borough: 'Brooklyn', cuisine: 'Italian' } }
update_one = { update_one:
{
filter: { name: 'Moonlit Tavern' },
update: { '$set': { borough: 'Queens' } }
}
}
delete_many = { delete_many: { name: 'Crepe' } }
writes = [insert_one, update_one, delete_many]
collection.bulk_write(writes)

쓰기 (write) 작업 중 하나라도 실패하면 Ruby 운전자 BulkWriteError 를 발생시키고 더 이상 작업을 수행하지 않습니다. BulkWriteError 은(는) 실패한 작업과 예외에 대한 세부 정보가 포함된 details 항목을 제공합니다.

참고

운전자 가 대량 작업을 실행할 때 대상 컬렉션 의 쓰기 고려 (write concern) 를 사용합니다. 운전자 는 실행 순서에 관계없이 모든 작업을 시도한 후 모든 쓰기 고려 (write concern) 오류를 보고합니다.

bulk_write 메서드는 대량 쓰기 (write) 작업을 구성하는 데 사용할 수 있는 옵션을 지정하는 options 해시를 선택적으로 허용합니다. 옵션을 지정하지 않으면 운전자 기본값 설정으로 대량 작업을 수행합니다.

다음 표에서는 bulk_write 메서드를 구성하는 데 사용할 수 있는 옵션에 대해 설명합니다.

옵션
설명

ordered

true인 경우 드라이버는 제공된 순서대로 쓰기 (write) 작업을 수행합니다. 오류가 발생하면 나머지 작업은 수행되지 않습니다.

false인 경우 드라이버는 임의의 순서대로 작업을 수행하고 모든 작업을 수행하려고 시도합니다.
기본값은 true입니다.

bypass_document_validation

업데이트 작업에서 문서 유효성 검사 우회할지 여부를 지정합니다. 이를 통해 스키마 유효성 검사 요구 사항을 충족하지 않는 문서(있는 경우)를 업데이트 수 있습니다. 스키마 유효성 검사 에 대한 자세한 내용은 MongoDB Server 매뉴얼의 스키마 유효성 검사 참조하세요.
기본값은 false 입니다.

session

작업에 사용할 세션입니다.
유형: Session

let

작업에 대한 최상위 변수를 설정하다 위해 매개변수 이름과 값의 맵을 제공합니다. 값은 문서 필드를 참조하지 않는 상수 또는 닫힌 표현식이어야 합니다.

다음 코드는 옵션을 생성하고 ordered 옵션을 false 로 설정하여 순서가 지정되지 않은 대량 쓰기 (write) 지정합니다. 그런 다음 이 코드는 bulk_write 메서드를 사용하여 앞의 예시 와 동일한 대량 작업을 수행합니다.

options = { ordered: false }
collection.bulk_write(writes, options)

순서가 지정되지 않은 대량 쓰기 (write) 의 쓰기 (write) 작업 중 하나라도 실패하면 Ruby 운전자 모든 작업을 시도한 후에만 오류를 보고합니다.

참고

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

bulk_write 메서드는 BulkWrite::Result을 반환합니다. 다음 인스턴스 메서드를 사용하여 Result 인스턴스 의 정보 액세스 수 있습니다.

메서드
설명

acknowledged?

서버가 쓰기 작업을 승인했는지 여부를 나타냅니다.

deleted_count

삭제된 문서 수를 반환합니다(있는 경우).

inserted_count

삽입된 문서 수를 반환합니다(있는 경우).

inserted_ids

삽입된 문서 ID(있는 경우)의 목록을 반환합니다.

matched_count

해당하는 경우 업데이트 와 일치하는 문서 수를 반환합니다.

modified_count

수정된 문서 수를 반환합니다(있는 경우).

upserted_count

업서트된 문서(있는 경우)의 수를 반환합니다.

upserted_ids

업서트된 문서 ID(있는 경우)의 목록을 반환합니다.

개별 쓰기 작업을 수행하는 방법을 알아보려면 다음 가이드를 참조하세요.

이 가이드에서 사용되는 메서드 또는 유형에 대해 자세히 알아보려면 다음 API 설명서를 참조하세요.