Computer >> 컴퓨터 >  >> 프로그램 작성 >> MongoDB

MongoDB에서 $set을 사용하여 중첩된 값/임베디드 문서를 업데이트하는 방법은 무엇입니까?

<시간/>

이에 대한 구문은 다음과 같습니다 -

db.yourCollectionName.update({ }, { $set: { "yourOuterFieldName.yourInnerFieldName": "yourValue" } });

구문을 이해하기 위해 문서로 컬렉션을 만들어 보겠습니다. 문서로 컬렉션을 생성하는 쿼리는 다음과 같습니다 -

> db.updateNestedValueDemo.insertOne({"CustomerName":"Chris",
   ... "CustomerDetails":{"CustomerAge":25,"CustomerCompanyName":"Google","CustomerCityName":"US"}});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c8fccc4d3c9d04998abf015")
}

find() 메서드를 사용하여 컬렉션의 모든 문서를 표시합니다. 쿼리는 다음과 같습니다 -

> db.updateNestedValueDemo.find().pretty();

다음은 출력입니다 -

{
   "_id" : ObjectId("5c8fccc4d3c9d04998abf015"),
   "CustomerName" : "Chris",
   "CustomerDetails" : {
      "CustomerAge" : 25,
      "CustomerCompanyName" : "Google",
      "CustomerCityName" : "US"
   }
}

다음은 중첩된 값/포함된 문서를 업데이트하기 위해 $set을 사용하는 쿼리입니다 -

> db.updateNestedValueDemo.update({ }, { $set: { "CustomerDetails.CustomerCompanyName": "Dell" } });
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

find() 메소드를 사용하여 컬렉션에서 문서를 확인합시다 -

> db.updateNestedValueDemo.find().pretty();

다음은 출력입니다 -

{
   "_id" : ObjectId("5c8fccc4d3c9d04998abf015"),
   "CustomerName" : "Chris",
   "CustomerDetails" : {
      "CustomerAge" : 25,
      "CustomerCompanyName" : "Dell",
      "CustomerCityName" : "US"
   }
}

위의 샘플 출력을 보면 중첩 필드 "CustomerCompanyName"이 "Google"에서 "Dell"로 변경되었습니다.