[英]Mongoose/MongoDB how to query nested documents as a single array
集合中的一項看起來如下所示。
{
"_id" : ObjectId("4f7ee46e08403d063ab0b4f9"),
"name" : "MongoDB",
"notes" : [
{
"title" : "Hello MongoDB",
"content" : "Hello MongoDB"
},
{
"title" : "ReplicaSet MongoDB",
"content" : "ReplicaSet MongoDB"
}
]
}
可以說我想以單個數組的形式檢索所有文檔的所有注釋,我應該如何查詢? 給出mongoose和或mongoDB示例
您可以使用聚合來獲得期望的結果。 使用$unwind
階段將數組值展平為文檔。 然后,在$group
階段之后, $push
所有音符$push
入單個數組中。 (可選)使用$project
階段輸出期望的字段。
db.collection.aggregate([
{"$unwind":"$notes"},
{"$group":{"_id": null, "notes":{"$push":"$notes"}}},
{"$project":{"_id":0, "notes":1}}
]);
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.