如何在 MongoDB 中刪除不滿足條件的元素?


要刪除元素,請使用 $pull,對於這樣的條件,請使用 $ne。MongoDB 中的 $ne 用於選擇欄位值不等於指定值的檔案。

讓我們建立一個包含檔案的集合 -

> db.demo410.insertOne(
...    {
...       details: [{isMarried:false}, {isMarried:true}, {isMarried:false}, {isMarried:"Chris"}]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e70efc515dc524f70227681")
}

使用 find() 方法顯示集合中的所有檔案 -

> db.demo410.find();

這將產生以下輸出 -

{ "_id" : ObjectId("5e70efc515dc524f70227681"), "details" : [ { "isMarried" : false }, { "isMarried" : true }, { "isMarried" : false }, { "isMarried" : "Chris" } ] }

以下是在 MongoDB 中刪除不滿足條件的元素的查詢 -

> db.demo410.updateMany(
...    { "details": { "$elemMatch": { "isMarried": { "$ne": true } } } },
...    { "$pull": { "details": { "isMarried": { "$ne": true } } } }
... )
{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 }

使用 find() 方法顯示集合中的所有檔案 -

> db.demo410.find();

這將產生以下輸出 -

{ "_id" : ObjectId("5e70efc515dc524f70227681"), "details" : [ { "isMarried" : true } ] }

更新於: 03-04-2020

352 次瀏覽

開啟你的 職業生涯

透過完成課程獲得認證

開始
廣告
© . All rights reserved.