如何在 MongoDB 中刪除子集合中的物件?


要刪除子集合中的物件,請在 MongoDB 中使用 $pull。讓我們建立一個文件集合 −

> db.demo715.insertOne({
...    _id:1,
...    details :
...    [
...       { 'id' : '101',
...       'Information' : [
...          {
...             'studentid' : '102',
...             "Name":"Bob"
...          },
...          {
...             'studentid' : '103',
...             "Name":"Chris"
...          }
...       ]
...    }
... ]
... });
{ "acknowledged" : true, "insertedId" : 1 }

藉助 find() 方法顯示集合中的所有文件 −

> db.demo715.find();

這將產生以下輸出 −

{ "_id" : 1, "details" : [ { "id" : "101", "Information" : [ { "studentid" : "102", "Name" : "Bob" }, { "studentid" : "103", "Name" : "Chris" } ] } ] }

以下是 MongoDB 中刪除子集合中物件的查詢 −

> db.demo715.update(
...    {"details.id":'101'},
...    { $pull: { 'details.$.Information':{studentid:'102',"Name":"Bob"} } }
... );
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

藉助 find() 方法顯示集合中的所有文件 −

> db.demo715.find();

這將產生以下輸出 −

{ "_id" : 1, "details" : [ { "id" : "101", "Information" : [ { "studentid" : "103", "Name" : "Chris" } ] } ] }

更新於:2020 年 5 月 14 日

522 次瀏覽

職業生涯開局

完成課程獲得認證

開始
廣告