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

MongoDBの別の配列内にネストされた配列から特定のレコードを削除する


特定のレコードを削除するには、「$ pull」を使用し、作成済みのコレクションを更新しているため、UPDATE()を使用します。

ドキュメントを使用してコレクションを作成しましょう-

> db.demo213.insertOne({
...   "id": 101,
...   "details1": [
...      {
...         "Name": "Chris",
...         "details2": [
...            {
...               "StudentName": "David",
...               "Subject": "MongoDB"
...            },
...            {
...               "StudentName": "Mike",
...               "Subject": "MySQL"
...            }
...         ]
...
...      }
...   ]
...}
...);
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e3e300c03d395bdc2134704")
}

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

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

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

{
   "_id" : ObjectId("5e3e300c03d395bdc2134704"),
   "id" : 101,
   "details1" : [
      {
         "Name" : "Chris",
         "details2" : [
            {
               "StudentName" : "David",
               "Subject" : "MongoDB"
            },
            {
               "StudentName" : "Mike",
               "Subject" : "MySQL"
            }
         ]
      }
   ]
}

以下は、別の配列内にネストされた配列から特定のレコードを削除するためのクエリです-

> db.demo213.update({"id": 101, "details1.Name": "Chris"},
...   {
...      "$pull": {"details1.$.details2" : { "Subject": "MySQL" }}
...   }, multi=true
...)
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

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

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

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

{
   "_id" : ObjectId("5e3e300c03d395bdc2134704"),
   "id" : 101,
   "details1" : [
      {
         "Name" : "Chris",
         "details2" : [
            {
               "StudentName" : "David",
               "Subject" : "MongoDB"
            }
         ]
      }
   ]
}

  1. MongoDBドキュメントの特定のフィールドから配列要素の数を取得しますか?

    特定のフィールドから配列要素をカウントするには、MongoDBで$sizeを使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo723.insertOne({"Subject":["MySQL","MongoDB"]}); {    "acknowledged" : true,    "insertedId" : ObjectId("5eab094d43417811278f588a") } >

  2. MongoDBを使用して、特定のネストされたドキュメントのオブジェクトの配列をクエリしますか?

    ネストされたドキュメントのオブジェクトの配列をクエリするには、find()を使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo763.insertOne( ...    { ...       _id:1, ...       CountryName:"US", ...       "studentInformation": [ ...          {