MongoDB
 Computer >> コンピューター >  >> プログラミング >> MongoDB

MongoDBのサブ配列のサブにある要素をプルしますか?


要素をプルするには、$ pullと$(positional)演算子を使用します。ドキュメントを使用してコレクションを作成しましょう-

> db.demo679.insertOne(
...    {
...       id:1,
...       "details": [
...          {
...             CountryName:"US",
...             "information": [
...
...                { "Name": "Chris", "FirstName": "Name=Chris" },
...
...                {"Name": "Bob", "FirstName": "Name=Bob" }
...             ]
...          },
...          {
...             CountryName:"UK",
...             "information": [
...
...                { "Name": "Robert", "FirstName": "Name=Robert" },
...
...                {"Name": "Sam", "FirstName": "Name=Sam" }
...             ]
...          }
...       ]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ea442cf04263e90dac943fd")
}

find()メソッドを使用してコレクションからすべてのドキュメントを表示する-

> db.demo679.find();

これにより、次の出力が生成されます-

{ "_id" : ObjectId("5ea442cf04263e90dac943fd"), "id" : 1, "details" : [
   { "CountryName" : "US", "information" :  [
      { "Name" : "Chris", "FirstName" : "Name=Chris" },
      { "Name" : "Bob", "FirstName" : "Name=Bob" }
   ] },
   { "CountryName" : "UK", "information" : [
      { "Name" : "Robert", "FirstName" : "Name=Robert" },
      { "Name" : "Sam", "FirstName" : "Name=Sam" }
   ] } 
] }

以下は、MongoDBのサブ配列のサブにある要素をプルするためのクエリです-

> db.demo679.update(
...    { "details.CountryName":"US" },
...    { $pull: { 'details.$.information': { "Name" : "Bob", "FirstName" : "Name=Bob" } } }
... );
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

find()メソッドを使用してコレクションからすべてのドキュメントを表示する-

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

これにより、次の出力が生成されます-

{
   "_id" : ObjectId("5ea442cf04263e90dac943fd"),
   "id" : 1,
   "details" : [
      {
         "CountryName" : "US",
         "information" : [
            {
               "Name" : "Chris",
               "FirstName" : "Name=Chris"
            }
         ]
      },
      {
         "CountryName" : "UK",
         "information" : [
            {
               "Name" : "Robert",
               "FirstName" : "Name=Robert"
            },
            {
               "Name" : "Sam",
               "FirstName" : "Name=Sam"
            }
         ]
      }
   ]
}

  1. MongoDBのJSON配列の内部要素にアクセスしますか?

    MongoDBのJSON配列の内部要素にアクセスするには、ドット表記を使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo687.insert({CountryName:'US', ... info: ... { ... id:101, ... details: ... [ ... { ...    Name:'Chris', ...    SubjectName:'MongoDB', ...    otherDetails:{ ...  

  2. MongoDBのサブドキュメントでサブドキュメントをフィルタリングしますか?

    これには、$ unwindと一緒にaggregate()を使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo583.insert([ ...    { ...       "details1" : [ ...          { ...             "details2" : [ ...         &