提取陣列多個值的 MongoDB 查詢
如需提取值,請使用 $pull 並設定 multi: true。我們先建立一個文集並使用文件 −
> db.demo392.insertOne(
... {
... Name: 'Chris',
... details: [
... {
... _id: '101'
...
... },
... {
... _id: '102'
... }
... ]
... }
... );
{
"acknowledged" : true,
"insertedId" : ObjectId("5e5d2b3322064be7ab44e802")
}
>
> db.demo392.insertOne(
... {
... Name: 'Chris',
... details: [
... {
... _id: '104'
...
... },
... {
... _id: '101'
... }
... ]
... }
... );
{
"acknowledged" : true,
"insertedId" : ObjectId("5e5d2b3422064be7ab44e803")
}在集合的幫助下從集合中顯示所有文件並使用 find() 方法 −
> db.demo392.find();
這將產生以下輸出 −
{
"_id" : ObjectId("5e5d2b3322064be7ab44e802"), "Name" : "Chris", "details" : [
{ "_id" : "101" }, { "_id" : "102" }
]
}
{
"_id" : ObjectId("5e5d2b3422064be7ab44e803"), "Name" : "Chris", "details" : [
{ "_id" : "104" }, { "_id" : "101" }
]
}以下是 $pull 至陣列的查詢 −
> db.demo392.update(
... { },
... { $pull: { details: { _id: '101' } } },
... { multi: true }
... )
WriteResult({ "nMatched" : 2, "nUpserted" : 0, "nModified" : 2 })在集合的幫助下從集合中顯示所有文件並使用 find() 方法 −
> db.demo392.find();
這將產生以下輸出 −
{ "_id" : ObjectId("5e5d2b3322064be7ab44e802"), "Name" : "Chris", "details" : [ { "_id" : "102" } ] }
{ "_id" : ObjectId("5e5d2b3422064be7ab44e803"), "Name" : "Chris", "details" : [ { "_id" : "104" } ] }
廣告
資料結構
網路
關係型資料庫管理系統
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP