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

MongoDB의 단일 배열 요소에서 속성을 설정 해제하시겠습니까?

<시간/>

$unset 연산자를 사용하여 속성을 설정 해제합니다. 먼저 문서로 컬렉션을 만들어 보겠습니다. −

> db.unsetAnAttributeDemo.insertOne(
...    {
...       _id: 1,
...       "StudentDetails": [
...          {
...             "StudentFirstName": "Ramit",
...             "StudentCountryName":"UK"
...          },
...          {
...             "StudentFirstName": "Bob",
...             "StudentCountryName":"US"
...          },
...          {
...             "StudentFirstName": "Carol",
...             "StudentCountryName":"AUS"
...
...          }
...       ]
...    }
... );
{ "acknowledged" : true, "insertedId" : 1 }

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

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

이것은 다음과 같은 출력을 생성합니다 -

{
   "_id" : 1,
   "StudentDetails" : [
      {
         "StudentFirstName" : "Ramit",
         "StudentCountryName" : "UK"
      },
      {
         "StudentFirstName" : "Bob",
         "StudentCountryName" : "US"
      },
      {
         "StudentFirstName" : "Carol",
         "StudentCountryName" : "AUS"
      }
   ]
}

다음은 단일 배열 요소에서 속성을 설정 해제하는 쿼리입니다. 값이 "AUS"인 "StudentCountryName" 속성이 설정 해제됩니다. −

> db.unsetAnAttributeDemo.update({"StudentDetails.StudentCountryName": "AUS"}, {$unset:
   {"StudentDetails.$.StudentCountryName": 1}});
   WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

값이 "AUS"인 StudentCountryName 속성이 지워졌는지 확인하기 위해 컬렉션의 문서를 표시해 보겠습니다. -

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

이것은 다음과 같은 출력을 생성합니다 -

{
   "_id" : 1,
   "StudentDetails" : [
      {
         "StudentFirstName" : "Ramit",
         "StudentCountryName" : "UK"
      },
      {
         "StudentFirstName" : "Bob",
         "StudentCountryName" : "US"
      },
      {
         "StudentFirstName" : "Carol"
      }
   ]
}