如何從 MongoDB 中的陣列中提取多個物件?
要從陣列中提取多個物件,可以使用 $pull 運算子。我們首先使用文件建立一個集合 -
> db.pullMultipleObjectsDemo.insertOne(
... {
... "ClientId" : "100",
... "ClientName" : "John",
... "ClientPersonalDetails" : [
... {
... "ClientCountryName" : "US",
... "ClientProjectName" : "Online Book Store",
...
... },
... {
... "ClientCountryName" : "AUS",
... "ClientProjectName" : "Online Fee Management",
...
... },
... {
... "ClientCountryName" : "UK",
... "ClientProjectName" : "Online Pig Dice Game",
...
... },
... {
... "ClientCountryName" : "ANGOLA",
... "ClientProjectName" : "Online Hospital Management",
...
... }
... ]
... }
... );
{
"acknowledged" : true,
"insertedId" : ObjectId("5cc7d0748f9e6ff3eb0ce43d")
}以下是查詢,用於使用 find() 方法顯示集合中的所有文件 -
> db.pullMultipleObjectsDemo.find().pretty();
這將產生以下輸出 -
{
"_id" : ObjectId("5cc7d0748f9e6ff3eb0ce43d"),
"ClientId" : "100",
"ClientName" : "John",
"ClientPersonalDetails" : [
{
"ClientCountryName" : "US",
"ClientProjectName" : "Online Book Store"
},
{
"ClientCountryName" : "AUS",
"ClientProjectName" : "Online Fee Management"
},
{
"ClientCountryName" : "UK",
"ClientProjectName" : "Online Pig Dice Game"
},
{
"ClientCountryName" : "ANGOLA",
"ClientProjectName" : "Online Hospital Management"
}
]
}以下是查詢,用於從陣列中提取多個物件 -
> db.pullMultipleObjectsDemo.update(
... {"_id": ObjectId("5cc7d0748f9e6ff3eb0ce43d")},
... {"$pull":{"ClientPersonalDetails":{"ClientProjectName":{$in:["Online Book Store","Online Pig Dice Game"]}}}}
... );
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })為了檢查物件是否已從陣列中移除,我們來顯示集合中的所有文件。查詢如下 -
> db.pullMultipleObjectsDemo.find().pretty();
這將產生以下輸出 -
{
"_id" : ObjectId("5cc7d0748f9e6ff3eb0ce43d"),
"ClientId" : "100",
"ClientName" : "John",
"ClientPersonalDetails" : [
{
"ClientCountryName" : "AUS",
"ClientProjectName" : "Online Fee Management"
},
{
"ClientCountryName" : "ANGOLA",
"ClientProjectName" : "Online Hospital Management"
}
]
}看看上面的示例輸出,已從陣列中移除多個物件。
廣告
資料結構
網路
RDBMS
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP