Join us at MongoDB.local London on 7 May to unlock new possibilities for your data. Use WEB50 to save 50%.
Register now >
Docs Menu
Docs Home
/ /

db. 컬렉션. 업데이트() (mongosh 메서드)

중요

더 이상 사용되지 않는 mongosh 메서드

이 메서드는 mongosh에서 더 이상 사용되지 않습니다. 대체 메서드는 레거시 mongo shell과의 호환성 변경 사항을 참조하세요.

db.collection.update(query, update, options)

컬렉션에 있는 기존 문서를 수정합니다. 이 메서드는 업데이트 매개변수에 따라 기존 문서의 특정 필드를 수정하거나 기존 문서를 완전히 대체할 수 있습니다.

기본적으로 db.collection.update() 메서드는 단일 문서를 업데이트합니다. 쿼리 기준과 일치하는 모든 문서를 업데이트하려면 multi: true 옵션을 포함하세요.

이 메서드는 다음 환경에서 호스팅되는 배포에서 사용할 수 있습니다.

  • MongoDB Atlas: 클라우드에서의 MongoDB 배포를 위한 완전 관리형 서비스

참고

이 명령은 모든 MongoDB Atlas 클러스터에서 지원됩니다. 모든 명령에 대한 Atlas 지원에 관해 자세히 알아보려면 지원되지 않는 명령을 참조하십시오.

  • MongoDB Enterprise: MongoDB의 구독 기반 자체 관리 버전

  • MongoDB Community: MongoDB의 소스 사용 가능 무료 자체 관리 버전

버전 5.0에서 변경됨

db.collection.update() 메서드의 형식은 다음과 같습니다.

db.collection.update(
<query>,
<update>,
{
upsert: <boolean>,
multi: <boolean>,
writeConcern: <document>,
collation: <document>,
arrayFilters: [ <filterdocument1>, ... ],
hint: <document|string>,
let: <document>,
maxTimeMS: <int>,
bypassDocumentValidation: <boolean>
}
)

db.collection.update() 메서드는 다음 매개변수를 사용합니다.

Parameter
유형
설명

문서

업데이트의 선택 기준입니다. 메서드와 동일한 쿼리 선택기find() 사용할 수 있습니다.

을 사용하여 을 실행하고 update() upsert: true 쿼리 와 일치하는 기존 문서 없는 경우 쿼리 _id 점 표기법사용하여 필드 에 조건을 지정하면 MongoDB 새 문서 삽입을 거부합니다.

문서 또는 파이프라인

수정 사항을 적용합니다. 다음 중 하나일 수 있습니다.

<field1>: <value1> 0}쌍만 포함합니다.

다음 집계 단계만 포함합니다.

자세한 내용과 예시는 oplog 항목을 참조하세요.

부울

선택 사항. trueupdate() 인 경우 다음 중 하나를 합니다.

  • 0}과 일치하는 문서가 없는 query 경우 새 문서를 만듭니다. 자세한 내용은 upsert 동작을 참조하세요.

  • query와 일치하는 단일 문서를 업데이트합니다.

upsertmulti가 모두 참이고 쿼리와 일치하는 문서가 없으면 업데이트 작업은 단일 문서만 삽입합니다.

업서트가 여러 query 발생하지 않도록 하려면 필드 고유하게 인덱싱해야 합니다. 예시 는 중복 값으로 업서트를 참조하세요.

기본값은 false이며, 일치하는 문서를 찾을 수 없을 때 새 문서를 삽입하지 않습니다.

부울

선택 사항. true로 설정하다 하면 query 기준을 충족하는 여러 문서를 업데이트합니다. false로 설정하다 하면 하나의 문서 업데이트합니다. 기본값 은 false입니다. 자세한 내용은 여러 문서 업데이트 예시를 참조하세요.

문서

선택 사항입니다. 쓰기 우려를 표현하는 문서입니다. 기본값 쓰기 고려를 사용하려면 w: "majority" 생략합니다.

트랜잭션에서 실행되는 경우 작업에 대한 쓰기 고려를 명시적으로 설정하지 마세요. 트랜잭션에 쓰기 고려를 사용하려면 트랜잭션 및 쓰기 고려를 참조하세요.

writeConcern 사용 예시 는 기본 쓰기 고려 재정의를 참조하세요.

문서

선택 사항.

데이터 정렬을 사용하면 대소문자 및 악센트 표시 규칙과 같은 문자열 비교에 대한 언어별 규칙을 지정할 수 있습니다.

사용예시 는 데이터 정렬 collation 지정을 참조하세요.

배열

선택 사항입니다. 필터 문서의 배열로, 배열 필드에 대한 업데이트 작업을 위해 수정할 배열 요소를 결정합니다.

업데이트 문서 에서 를 사용하여 $[<identifier>] 의 해당 필터하다 문서 와 일치하는 배열 요소만 업데이트 하는 arrayFilters 식별자를 정의합니다.

식별자가 업데이트 문서에 포함되어 있지 않으면 식별자에 대한 배열 필터 문서를 사용할 수 없습니다.

예제는 배열 업데이트 작업을 참조하세요.

문서 또는 문자열

선택 사항. 쿼리 조건자를 지원 데 사용할 인덱스지정하는 문서 또는 문자열입니다.

이 옵션은 인덱스 사양 문서 또는 인덱스 이름 문자열을 사용할 수 있습니다.

존재하지 않는 인덱스를 지정하면 연산 오류가 발생합니다.

예시 hint 는 업데이트 작업에 지정을 참조하세요.

문서

선택 사항.

변수 목록이 있는 문서를 지정합니다. 이를 통해 쿼리 텍스트에서 변수를 분리하여 명령 가독성을 향상시킬 수 있습니다.

문서 구문은 다음과 같습니다:

{
<variable_name_1>: <expression_1>,
...,
<variable_name_n>: <expression_n>
}

변수는 표현식에서 반환된 값으로 설정되며 이후에는 변경할 수 없습니다.

명령에서 변수 값에 액세스하려면 $$<variable_name> 형식의 이중 달러 기호 접두사 ($$) 를 변수 이름과 함께 사용하십시오.예시: $$targetTotal.

변수를 사용하여 결과를 필터링하려면 $expr 연산자 내에서 변수에 액세스해야 합니다.

및 변수를 사용하는 전체 예시 let 는 에서 변수 사용을 참조하세요.let

integer

선택 사항. 시간이 초과되기 전에 업데이트 작업을 실행 시간 제한을 밀리초 단위로 지정합니다.

부울

선택 사항입니다. insert가 작업 중에 스키마 유효성 검사를 우회할 수 있도록 합니다. 이를 통해 유효성 검사 요구 사항을 충족하지 않는 문서를 삽입할 수 있습니다.

이 메서드는 작업 상태가 포함된 WriteResult 문서를 반환합니다.

authorization으로 실행되는 배포에서 사용자에게 다음 권한이 포함된 액세스 권한이 있어야 합니다.

  • update 지정된 컬렉션에 대한 조치입니다.

  • find 지정된 컬렉션에 대한 조치입니다.

  • insert 작업은 해당 연산으로 인해 업서트가 발생하는 경우 지정된 컬렉션에 대한 작업입니다.

기본 제공 역할 readWrite은 이러한 권한을 제공합니다.

multi: true를 설정한 경우 update() 메서드는 멱등 연산에만 사용하세요.

$expr 연산자를 사용하려고 하면 업서트 플래그가 true로 설정된 상태에서 오류가 발생합니다.

샤딩된 컬렉션에서 db.collection.update()multi: false와 함께 사용하려면 _id 필드에 정확히 일치하는 항목을 포함하거나 단일 샤드를 대상으로 지정해야 합니다(예: 샤드 키 포함).

db.collection.update()가 업데이트 작업을 수행할 때(문서 교체 작업은 아님) db.collection.update()는 여러 샤드를 대상으로 할 수 있습니다.

문서 교체 작업은 먼저 쿼리 필터를 사용하여 단일 샤드를 대상으로 시도합니다. 작업이 쿼리 필터로 단일 샤드를 대상으로 지정할 수 없는 경우 대체 문서로 대상을 지정하려고 시도합니다.

이전 버전에서는 작업이 교체 문서를 사용하여 대상을 지정하려고 시도했습니다.

db.collection.update() 작업이 upsert: true를 포함하고 샤딩된 컬렉션에 있는 경우 filter에 전체 샤드 키를 포함해야 합니다.

  • 업데이트 작업의 경우.

  • 문서 바꾸기 작업의 경우.

그러나 샤딩된 컬렉션의 문서에는 샤드 키 필드가 누락될 수 있습니다. 샤드 키가 누락된 문서를 대상으로 하려면 null 동등성 매치를 다른 필터 조건(예: _id 필드)과 함께 사용할 수 있습니다. 예를 들면 다음과 같습니다.

{ _id: <value>, <shardkeyfield>: null } // _id of the document missing shard key

샤드 키 필드가 변경할 수 없는 _id 필드가 아닌 경우 문서의 샤드 키 값을 업데이트할 수 있습니다.

기존 샤드 키 값을 db.collection.update()으로 수정하려면 다음을 수행합니다.

  • 반드시 mongos에서 실행해야 합니다. 샤드에서 직접 작업을 실행하지 않아야 합니다.

  • 반드시 트랜잭션에서 실행하거나 재시도 가능 쓰기로 실행해야 합니다 .

  • 반드시 multi: false를 지정해야 합니다.

  • 전체 샤드 키에 동등 쿼리 필터포함해야 합니다.

누락된 키 값은 null 동등성 매치의 일부로 반환되므로 null 값 키가 업데이트되지 않도록 하려면 추가 쿼리 조건(예: _id 필드)을 적절히 포함하세요.

샤딩된 컬렉션에서 upsert도 참조하세요.

샤딩된 컬렉션의 문서에는 샤드 키 필드가 누락될 수 있습니다. db.collection.update()를 사용하여 문서의 누락된 샤드 키를 설정하려면 mongos에서 실행해야 합니다. 샤드에서 바로 연산을 실행하지는 마세요.

또한 다음 요구 사항도 적용됩니다.

작업
요구 사항:

설정 방법 null

  • multi: true를 지정할 수 있습니다.

  • upsert: true인 경우 전체 샤드 키에 대한 동일성 필터가 필요합니다.

null이 아닌 값으로 설정하려면 다음 단계를 따르세요.

  • 반드시 트랜잭션 내에서 또는 재시도 가능 쓰기로 수행해야 합니다.

  • multi: false지정해야 합니다.

  • 다음 중 하나의 경우 전체 샤드 키에 대해 동일성 필터가 필요합니다.

    • upsert: true또는

    • 교체 문서를 사용하고 새 샤드 키 값이 다른 샤드에 속하는 경우입니다.

누락된 키 값은 null 동등성 매치의 일부로 반환되므로 null 값 키가 업데이트되지 않도록 하려면 추가 쿼리 조건(예: _id 필드)을 적절히 포함하세요.

다음도 참조하세요.

db.collection.update()분산 트랜잭션 내에서 사용할 수 있습니다.

중요

대부분의 경우 분산 트랜잭션은 단일 문서 쓰기에 비해 더 큰 성능 비용이 발생하므로 분산 트랜잭션의 가용성이 효과적인 스키마 설계를 대체할 수는 없습니다. 대부분의 시나리오에서 비정규화된 데이터 모델 (내장된 문서 및 배열) 은 계속해서 데이터 및 사용 사례에 최적일 것입니다. 즉, 대부분의 시나리오에서 데이터를 적절하게 모델링하면 분산 트랜잭션의 필요성이 최소화됩니다.

추가 트랜잭션 사용 고려 사항(예: 런타임 제한 및 oplog 크기 제한)은 프로덕션 고려사항을 참조하세요.

트랜잭션이 교차 샤드 쓰기 트랜잭션(write transaction)이 아닌 경우 분산 트랜잭션 내에서 컬렉션과 인덱스를 생성할 수 있습니다.

upsert: truedb.collection.update()는 기존 컬렉션이나 존재하지 않는 컬렉션에서 실행될 수 있습니다. 존재하지 않는 컬렉션에서 실행하면 작업이 컬렉션을 만듭니다.

트랜잭션에서 실행되는 경우 작업에 대한 쓰기 고려를 명시적으로 설정하지 마세요. 트랜잭션에 쓰기 고려를 사용하려면 트랜잭션 및 쓰기 고려를 참조하세요.

db.collection.update() 작업이 문서를 한 개 이상 성공적으로 업데이트하는 경우 작업은 업데이트된 문서마다 oplog(작업 로그)에 항목을 추가합니다. 작업이 실패하거나 업데이트할 문서를 찾지 못하면 작업은 oplog에 항목을 추가하지 않습니다.

upsert: trueupdate()를 실행할 때 쿼리와 일치하는 기존 문서가 없는 경우, 쿼리가 점 표기법을 사용하여 _id 필드에 조건을 지정하면 MongoDB는 새 문서 삽입을 거부합니다.

이 제한은 _id 문서에 포함된 필드 순서가 잘 정의되고 쿼리에 지정된 순서에 바인딩되지 않도록 합니다.

이러한 방식으로 문서 삽입하려고 하면 MongoDB 오류가 발생합니다.

중복을 방지하는 고유 인덱스 가 없는 경우 업서트는 중복 문서를 생성할 수 있습니다.

클라이언트가 데이터를 성공적으로 삽입하기 전에 모든 db.collection.update() 작업이 쿼리 단계를 완료하고, 그리고 name 필드에 고유 인덱스가 없는 경우 각 db.collection.update() 작업에서 삽입이 발생하여 name: Andy(으)로 여러 문서가 생성될 수 있습니다.

name 필드 의 고유 인덱스 하나의 문서 만 생성되도록 합니다. 고유 인덱스 적용되면 이제 여러 db.collection.update() 작업이 다음과 같은 동작을 나타냅니다.

  • 정확히 하나의 db.collection.update() 작업으로 새 항목이 성공적으로 삽입됩니다.
    문서.
  • 다른 db.collection.update() 작업은 새로 삽입 업데이트

    문서 또는 고유 키 충돌로 인해 실패합니다.

    다른 db.collection.update() 작업에서 새로 삽입된 문서 업데이트 하려면 다음 조건을 모두 충족해야 합니다.

    • 대상 컬렉션 다음을 유발하는 고유 인덱스 가 있습니다.
      중복 키 오류.
    • 업데이트 작업이 updateMany 이 아니거나 multi 이(가)
      false.
    • 업데이트 일치 조건은 둘 중 하나입니다:

      • 단일 동등성 조건자. 예를 들면 다음과 같습니다. { "fieldA" : "valueA" }

      • 동등성 조건자의 논리적 AND. 예를 들면 다음과 같습니다. { "fieldA" : "valueA", "fieldB" : "valueB" }

    • 등호 조건자의 필드는 다음 필드와 일치합니다.
      고유 인덱스 키 패턴.
    • 업데이트 작업은 다음의 어떤 필드도 수정하지 않습니다.
      고유 인덱스 키 패턴.

업데이트 문서에서 $[<identifier>] 필터링된 위치 연산자를 사용하여 식별자를 정의한 다음 배열 필터 문서에서 이를 참조합니다. 식별자가 업데이트 문서에 포함되어 있지 않으면 식별자에 대한 배열 필터 문서를 가질 수 없습니다.

<identifier>는 소문자로 시작해야 하며 영숫자만 포함할 수 있습니다.

업데이트 문서에 동일한 식별자를 여러 번 포함할 수 있습니다. 그러나 업데이트 문서의 각 고유 식별자($[identifier])에 대해 해당 정확히 하나 만 배열 필터 문서를 지정해야 합니다. 즉, 동일한 식별자에 대해 여러 배열 필터 문서를 지정할 수 없습니다. 그러나 단일 필터 문서에서 동일한 식별자에 복합 조건을 지정할 수 있습니다.

참고

arrayFilters 은 집계 파이프라인을 사용하는 업데이트에는 사용할 수 없습니다.

db.collection.update() 메서드는 작업 상태가 포함된 WriteResult() 객체 반환합니다. 성공 하면 WriteResult() 객체 에는 쿼리 조건과 일치하는 문서 수, 업데이트 로 삽입된 문서 수, 수정된 문서 수가 포함됩니다.

db.collection.update() 메서드에서 쓰기 고려 (write concern) 오류가 발생하면 결과에 WriteResult.writeConcernError 필드 포함됩니다.

다음 표에서는 WriteResult.writeConcernError.provenance의 가능한 값에 대해 설명합니다.

출처
설명

clientSupplied

쓰기 우려 사항은 애플리케이션에서 지정되었습니다.

customDefault

쓰기 고려는 사용자 정의된 기본값에서 비롯된 것입니다. setDefaultRWConcern을 참조하십시오.

getLastErrorDefaults

쓰기 고려는 복제본 세트의 settings.getLastErrorDefaults 필드에서 발생했습니다.

implicitDefault

쓰기 고려는 다른 모든 쓰기 고려 사양이 없는 상태에서 서버에서 발생했습니다.

db.collection.update() 메서드에서 비 쓰기 고려 (write concern) 오류가 발생하면 결과에 WriteResult.writeError 필드 포함됩니다.

이 페이지의 예시에서는 sample_mflix 샘플 데이터 세트의 데이터를 사용합니다. 이 데이터 세트를 자체 관리형 MongoDB 배포서버에 로드하는 방법에 대한 자세한 내용은 샘플 데이터 세트 로드를 참조하세요. 샘플 데이터베이스를 수정한 경우 이 페이지의 예시를 실행 하려면 데이터베이스를 제거하고 다시 만들어야 할 수 있습니다.

$set 수정자를 사용하는 것과 같이 <update> 문서에 업데이트 연산자 수정자가 포함된 경우, 다음을 수행하세요.

  • <update> 문서에는 업데이트 연산자 표현식만 포함되어야 합니다.

  • db.collection.update() 메서드는 문서의 해당 필드만 업데이트합니다.

    • 내장된 문서 또는 배열을 전체적으로 업데이트하려면 필드에 대한 대체 값을 지정하십시오.

    • 내장된 문서 또는 배열의 특정 필드를 업데이트하려면 점 표기법을 사용하여 필드를 지정합니다.

db.movies.update(
{ title: "The Godfather" },
{
$inc: { "tomatoes.viewer.numReviews": 1 },
$set: {
"tomatoes.viewer.meter": 99
}
}
)
/* Corresponds to the following SQL statement:
* UPDATE movies
* SET tomatoes_viewer_numReviews = tomatoes_viewer_numReviews + 1,
* tomatoes_viewer_meter = 99
* WHERE title = "The Godfather"
*/

이 작업에서는 다음을 수행합니다.

  • { title: "The Godfather" }<query> 매개변수는 업데이트 할 문서 지정합니다.

  • $inc 연산자 tomatoes.viewer 내장된 문서 의 numReviews 필드 증가시킵니다.

  • $set 연산자 tomatoes.viewer 내장된 문서 의 meter 필드 업데이트합니다.

query 매개변수가 여러 문서와 일치하는 경우 작업은 일치하는 문서 하나만 업데이트합니다. 여러 문서를 업데이트하려면 multi 옵션을 true 로 설정하세요.

다음 작업은 $push 업데이트 연산자를 사용하여 genres 배열에 값을 추가합니다.

db.movies.update(
{ title: "The Matrix" },
{
$push: { genres: "Thriller" }
}
)

업데이트 후에는 genres 배열 새 값이 포함됩니다.

다음 작업은 $unset 연산자를 사용하여 "The Godfather" 문서에서 metacritic 필드를 제거합니다.

db.movies.update(
{ title: "The Godfather" },
{ $unset: { metacritic: "" } }
)
/* $unset is similar (but not identical) to the following SQL
command which removes the ``metacritic`` field from the ``movies``
table
* UPDATE movies
* SET metacritic = NULL
* WHERE title = "The Godfather"
*/

업데이트 후 metacritic 필드 제거됩니다.

multi이(가) true(으)로 설정된 경우 db.collection.update() 메서드는 <query> 조건을 충족하는 모든 문서를 업데이트합니다. multi 업데이트 작업은 다른 읽기/쓰기 작업에 끼어들 수 있습니다.

다음 작업은 제목이 'The Godfather' 또는 'The 매트릭스'인 문서에 대해 test_field 필드 true 로 설정합니다.

db.movies.update(
{ title: { $in: ["The Godfather", "The Matrix"] } },
{ $set: { test_field: true } },
{ multi: true }
)
/* Corresponds to the following SQL statement:
* UPDATE movies
* SET test_field = true
* WHERE title IN ('The Godfather', 'The Matrix')
*/

이 작업은 일치하는 문서를 모두 업데이트합니다.

교체를 수행할 때 multi: true를 지정할 수 없으며 업데이트 문서에 field:value 표현식 포함되어 있습니다.

upsert: true옵션을 지정하는 경우:

샤딩된 컬렉션에 upsert: true를 지정하는 경우 filter에 전체 샤드 키를 포함해야 합니다. 샤딩된 컬렉션에 대한 추가 db.collection.update() 동작은 샤딩된 컬렉션을 참조하세요.

다음 탭에서는 update()와 함께 upsert 수정자를 다양하게 사용하는 방법을 보여 줍니다.

쿼리 기준과 일치하는 문서가 없고 <update> 매개변수가 대체 문서인 경우(즉, 필드와 값 쌍만 포함된 경우) 업데이트는 대체 문서의 필드와 값으로 새 문서를 삽입합니다.

  • 쿼리 매개 변수 또는 대체 문서에서 _id 필드를 지정하는 경우 MongoDB는 삽입된 문서에서 해당 _id 필드를 사용합니다.

  • 쿼리 매개변수나 대체 문서에 _id 필드를 지정하지 않으면 MongoDB는 무작위로 생성된 ObjectId 값으로 _id 필드를 추가합니다.

    쿼리 매개변수와 대체 문서에 다른 _id 필드 값을 지정할 수 없습니다. 그렇게 하면 작동 오류가 발생합니다.

예를 들어 다음 업데이트는 업서트 옵션을 true로 설정합니다.

db.movies.update(
{ title: "Test Movie 12345" },
{
$set: {
title: "Test Movie 12345",
year: 2024,
genres: [ "Documentary" ],
rated: "NR"
}
},
{ upsert: true }
)

<query> 매개변수와 일치하는 문서 없는 경우 업데이트 작업은 대체 문서 만 있는 문서 삽입합니다. 대체 문서 또는 쿼리 문서 에 _id 필드 지정되지 않았으므로 이 작업은 새 문서의 _id 필드 에 대해 고유한 ObjectId 를 새로 만듭니다. 작업의 WriteResultupsert 가 반영된 것을 볼 수 있습니다.

쿼리 기준과 일치하는 문서가 없고 <update> 매개변수가 업데이트 연산자 표현식이 있는 문서인 경우 작업은 <query> 매개변수의 등호 절에서 기본 문서를 생성하고 <update> 매개변수의 표현식을 적용합니다.

<query>비교 작업은 새 문서 에 포함되지 않습니다. 새 문서 에 _id 필드 가 포함되지 않은 경우 MongoDB 는 ObjectId 값과 함께 _id 필드 를 추가합니다.

예를 들어 다음 업데이트는 업서트 옵션을 true로 설정합니다.

db.movies.update(
{ title: "Test Movie 67890" }, // Query parameter
{ // Update document
$set: { rated: "PG" },
$setOnInsert: { year: 2024, type: "movie" }
},
{ upsert: true } // Options
)

쿼리 조건과 일치하는 문서가 없는 경우 작업은 해당 문서 삽입합니다.

<update> 매개변수가 집계 파이프라인인 경우 업데이트에서는 <query> 매개변수의 동등 조항을 사용하여 기본 문서를 만든 다음 해당 파이프라인을 문서에 적용하여 삽입할 문서를 만듭니다. 새 문서에 _id 필드가 포함되어 있지 않으면 MongoDB는 ObjectId 값과 함께 _id 필드를 추가합니다.

예시 를 들어 다음 집계 파이프라인 쿼리 필터하다 와 일치하는 기존 문서 없기 때문에 movies 컬렉션 에 새 문서 삽입합니다.

db.movies.update(
{ title: "Test Movie ABC123" }, // Query parameter
[ // Aggregation pipeline
{ $set: {
year: 2024,
type: "movie",
rated: "NR",
lastModified: "$$NOW"
} }
],
{ upsert: true } // Options
)

집계 파이프라인을 사용한 업데이트의 더 많은 예시는 집계 파이프라인을 사용한 업데이트를 참조하세요.

다음 작업은 multi 옵션과 upsert 옵션을 모두 지정합니다. 일치하는 문서가 있는 경우, 이 작업은 일치하는 모든 문서를 업데이트합니다. 일치하는 문서가 없는 경우 새 문서가 삽입됩니다.

db.movies.update(
{ title: { $in: ["The Godfather", "The Matrix"] } },
{ $set: { test_upsert_field: true } },
{ upsert: true, multi: true }
)

두 영화가 모두 컬렉션 에 존재하므로 이 작업은 일치하는 문서를 모두 업데이트합니다.

컬렉션에 일치하는 문서가 없는 경우, 조작은 <query><update> 사양 모두의 필드를 사용하여 단일 문서를 삽입하는 결과를 낳습니다. 예를 들어 다음 작업을 가정해 보겠습니다.

db.movies.update(
{ "title": "Test Movie Unique789" },
{ $set: { year: 2024, type: "movie" } },
{ upsert: true, multi: true }
)

이 작업은 해당 문서 movies 컬렉션 에 삽입합니다.

db.collection.update() 메서드는 수행할 수정 사항을 지정하는 집계 파이프라인 [ <stage1>, <stage2>, ... ]을(를) 허용할 수 있습니다. 파이프라인은 다음 단계로 구성될 수 있습니다.

집계 파이프라인e을 사용하면 현재 필드 값을 기반으로 조건부 업데이트를 표현하거나 다른 필드의 값을 사용하여 한 필드를 업데이트하는 등 보다 표현력이 풍부한 업데이트 구문을 작성할 수 있습니다.

다음 예시 영화의 제목과 연도를 이러한 작업을 수행하는 집계 파이프라인 과 결합하는 displayTitle 필드 만듭니다.

  • titleyear 필드를 연결하여 displayTitle 필드 생성합니다.

  • lastModified 타임스탬프를 설정합니다.

db.movies.update(
{ title: "The Godfather" },
[
{ $set: {
displayTitle: { $concat: [ "$title", " (", { $toString: "$year" }, ")" ] },
lastModified: "$$NOW"
}
}
]
)

다음 예시 2015 에 개봉된 영화를 업데이트하여 IMDB와 토마토 평점을 합산한 평점 점수를 계산하고 점수에 따라 등급을 할당합니다.

db.movies.update(
{
year: 2015,
"imdb.rating": { $type: "number" },
"tomatoes.viewer.rating": { $type: "number" }
},
[
{ $set: {
combinedScore: {
$round: [
{ $avg: [
{ $multiply: [ "$imdb.rating", 10 ] },
{ $multiply: [ "$tomatoes.viewer.rating", 10 ] }
] },
1
]
},
lastUpdate: "$$NOW"
}
},
{ $set: {
grade: {
$switch: {
branches: [
{ case: { $gte: [ "$combinedScore", 80 ] }, then: "A" },
{ case: { $gte: [ "$combinedScore", 70 ] }, then: "B" },
{ case: { $gte: [ "$combinedScore", 60 ] }, then: "C" },
{ case: { $gte: [ "$combinedScore", 50 ] }, then: "D" }
],
default: "F"
}
}
}
}
],
{ multi: true }
)

참고

파이프라인에 사용된 $set는 업데이트 연산자 $set가 아닌 집계 단계 $set를 참조합니다.

$set 단계:

  • IMDB 평점(10 단위로 조정됨)과 토마토 시청률(10 단위로 조정됨)을 평균화한 다음 소수점 한 자리로 반올림하여 새 필드 combinedScore 을(를) 계산합니다. $avg, $multiply$round 를 참조하세요.

  • 필드 lastUpdate를 집계 변수 NOW 값으로 설정합니다.

  • $switch 연산자를 사용하여 combinedScore 을 기준으로 문자 등급을 할당합니다.

지정된 기준과 일치하는 모든 배열 요소를 업데이트하려면 arrayFilters 매개변수를 사용합니다.

다음 예시 languages 배열 에 "English" 이 있는 모든 영화를 업데이트합니다. 이 작업은 "English""EN"로 바꿉니다.

db.movies.update(
{ languages: "English" },
{ $set: { "languages.$[element]" : "EN" } },
{
arrayFilters: [ { "element": "English" } ],
multi: true
}
)

필터링된 위치 연산자와 함께 arrayFilters 매개 변수를 사용하여 패턴과 일치하는 특정 배열 요소를 업데이트할 수도 있습니다.

다음 예시 writers 배열 있는 기존 컬렉션 의 'The Godfather' 영화를 사용합니다. 이 작업은 접미사를 추가하여 이름에 '시나리오'가 포함된 작성자만 업데이트합니다.

db.movies.update(
{ title: "The Godfather" },
{ $set: { "writers.$[elem]" : { $concat: [ "$elem", " - UPDATED" ] } } },
{
arrayFilters: [ { "elem": { $regex: /screenplay/ } } ]
}
)

이 작업은 "The Godfather" 문서 대상으로 하고 필터 기준과 일치하는 배열 요소만 업데이트합니다. 작업 후 각본 작업을 수행한 작가에게는 ' - 업데이트됨'이 추가됩니다.

hint 옵션을 사용하면 MongoDB 업데이트 작업에 사용할 인덱스 지정할 수 있습니다. 이는 여러 문서를 업데이트하고 성능을 위해 특정 인덱스 사용되도록 하려는 경우에 유용합니다. 이 예시 sample_mflix 데이터베이스 의 기존 movies 컬렉션 사용합니다.

먼저 year 필드 에 인덱스 만듭니다.

db.movies.createIndex( { year: 1 } )

다음 업데이트 작업은 { year: 1 } 인덱스를 사용하여 2010-2015의 모든 영화를 업데이트하도록 명시적으로 제안합니다.

db.movies.update(
{ year: { $gte: 2010, $lte: 2015 } }, // Query parameter
{ $set: { decade: "2010s" } }, // Update document
{ multi: true, hint: { year: 1 } } // Options
)

참고

존재하지 않는 인덱스를 지정하면 연산 오류가 발생합니다.

사용된 인덱스를 보려면 작업에 대해 explain을 실행하세요.

db.movies.explain().update(
{ title: "The Godfather", year: { $gte: 1970 } },
{ $set: { test_hint_field: true } },
{ hint: { year: 1 } }
)

db.collection.explain().update()은 문서를 수정하지 않습니다.

버전 5.0에 추가.

명령의 다른 곳에서 액세스할 수 있는 변수를 정의하려면 let 옵션을 사용합니다.

참고

변수를 사용하여 결과를 필터링하려면 $expr 연산자 내에서 변수에 액세스해야 합니다.

예시입니다:

  • let 옵션에서 두 개의 변수를 정의합니다: targetTitle ( "The 매트릭스"로 설정하다 ) 및 newTitle ("매트릭스 리로디드"로 설정하다 )

  • 쿼리 필터하다 에서 $expr 을 사용하여 문서의 title 필드 $$targetTitle 변수와 비교합니다.

  • $set 과 함께 집계 파이프라인 사용하여 title 필드 $$newTitle값으로 업데이트 .

db.movies.update(
{ $expr: { $eq: [ "$title", "$$targetTitle" ] } },
[ { $set: { sequel: "$$sequelTitle" } } ],
{ let : { targetTitle: "The Matrix", sequelTitle: "The Matrix Reloaded" } }
)

복제본 집합에 대한 다음 작업은 w: 2쓰기 우려를 5000밀리초의 wtimeout 으로 지정합니다. 이 작업은 쓰기가 운영 서버와 보조 서버 모두에 전파되거나 5초 후에 타임아웃된 후에 반환됩니다.

db.movies.update(
{ num_mflix_comments: { $lte: 10 } },
{ $set: { featured: true } },
{
multi: true,
writeConcern: { w: 2, j: true, wtimeout: 5000 }
}
)

w: 2에 지정된 대로 프라이머리 와 하나 이상의 세컨더리 에서 쓰기 (write) 확인한 후 작업이 성공적으로 완료됩니다.

버전 8.1.2에서 변경되었습니다.

db.collection.update() 이 샤딩된 클러스터의 mongos 에서 실행되면 하나 이상의 다른 오류가 발생하더라도 항상 응답에서 writeConcernError 이 보고됩니다. 이전 릴리스에서는 다른 오류로 인해 db.collection.update() 가 쓰기 고려 (write concern) 오류를 보고하지 않는 경우가 있었습니다.

예시 들어, 문서 유효성 검사 실패하여 DocumentValidationFailed 오류를 트리거하고 쓰기 고려 (write concern) 오류도 발생하면 응답의 최상위 필드 에 DocumentValidationFailed 오류와 writeConcernError 가 모두 반환됩니다.

작업에 사용할 데이터 정렬을 지정합니다.

데이터 정렬을 사용하면 대소문자 및 악센트 표시 규칙과 같은 문자열 비교에 대한 언어별 규칙을 지정할 수 있습니다.

데이터 정렬 옵션의 구문은 다음과 같습니다:

collation: {
locale: <string>,
caseLevel: <boolean>,
caseFirst: <string>,
strength: <int>,
numericOrdering: <boolean>,
alternate: <string>,
maxVariable: <string>,
backwards: <boolean>
}

데이터 정렬을 지정할 때 locale 필드는 필수이고, 다른 데이터 정렬 필드는 모두 선택 사항입니다. 필드에 대한 설명은 데이터 정렬 문서를 참조하세요.

데이터 정렬이 지정되지 않았지만 컬렉션에 기본 데이터 정렬이 있는 경우( db.createCollection() 참조), 작업은 컬렉션에 지정된 데이터 정렬을 사용합니다.

컬렉션 또는 연산에 대한 데이터 정렬이 지정되지 않은 경우, MongoDB는 이전 버전에서 문자열 비교에 사용된 간단한 이진 비교를 사용합니다.

한 연산에 대해 여러 데이터 정렬을 지정할 수 없습니다. 예를 들어 필드별로 서로 다른 데이터 정렬을 지정할 수 없으며 정렬과 함께 찾기를 수행하는 경우 찾기 와 정렬에서 각각 다른 데이터 정렬을 사용하는 것은 허용되지 않습니다.

이 작업은 제목이 night 로 시작하고 대소문자를 구분하지 않는 비교를 위해 strength: 1 을 사용하는 모든 영화를 업데이트합니다.

db.movies.update(
{ title: /^night/i },
{ $set: { updated: true } },
{
collation: { locale: "en", strength: 1 },
multi: true
}
)

돌아가기

db.collection.unhideIndex

이 페이지의 내용