이에 대한 구문은 다음과 같습니다 -
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"로 변경되었습니다.