如何在 MongoDB 中從文件中刪除陣列值?


若要刪除陣列值,請在 MongoDB 中使用 $pull。$pull 運算子從現有陣列中刪除所有與指定條件匹配的值或值的例項。

我們先建立一個帶文件的集合 -

> db.demo535.insertOne(
... {
...
...    "studentId" : "101",
...    "studentName" : "Chris",
...    "ListOfMailIds" : [
...       "Chris@gmail.com",
...       "Chris@yahoo.com"
...    ]
...
... }
... )
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8c82bfef4dcbee04fbbc00")
}

在集合中利用 find() 方法顯示所有文件 -

> db.demo535.find();

這會產生以下輸出 -

{ "_id" : ObjectId("5e8c82bfef4dcbee04fbbc00"), "studentId" : "101", "studentName" : "Chris",
"ListOfMailIds" : [ "Chris@gmail.com", "Chris@yahoo.com" ] }

以下是刪除 MongoDB 文件中陣列值查詢 -

> db.demo535.update(
... { _id: ObjectId("5e8c82bfef4dcbee04fbbc00") },
... { $pull: { 'ListOfMailIds': 'Chris@yahoo.com' } }
... );
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

在集合中利用 find() 方法顯示所有文件 -

> db.demo535.find();

這會產生以下輸出 -

{ "_id" : ObjectId("5e8c82bfef4dcbee04fbbc00"), "studentId" : "101", "studentName" : "Chris", "ListOfMailIds" : [ "Chris@gmail.com" ] }

更新於:14-May-2020

414 檢視

開啟您的 職業生涯

完成課程獲得認證

入門
廣告
© . All rights reserved.