如何在 MongoDB 中按子文件排序、選擇和查詢?


若要排序,在 MongoDB 中使用 $sort。讓我們使用文件建立一個集合 −

> db.demo236.insertOne({"details":{"Name":"Chris","Age":21}});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e419015f4cebbeaebec514c")
}
> db.demo236.insertOne({"details":{"Name":"David","Age":23}});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e41901cf4cebbeaebec514d")
}
> db.demo236.insertOne({"details":{"Name":"Bob","Age":24}});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e419023f4cebbeaebec514e")
}

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

> db.demo236.find();

這將產生以下輸出 −

{ "_id" : ObjectId("5e419015f4cebbeaebec514c"), "details" : { "Name" : "Chris", "Age" : 21 } }
{ "_id" : ObjectId("5e41901cf4cebbeaebec514d"), "details" : { "Name" : "David", "Age" : 23 } }
{ "_id" : ObjectId("5e419023f4cebbeaebec514e"), "details" : { "Name" : "Bob", "Age" : 24 } }

以下是 MongoDB 中對子文件進行排序、選擇和查詢的查詢 −

>  db.demo236.aggregate(
...   [
...      { $unwind: "$details" },
...      { $project: {
...         Name: '$details.Name',
...         Age: '$details.Age'
...
...      }},
...   { $sort: {Name: -1}}
...]
...);

這將產生以下輸出 −

{ "_id" : ObjectId("5e41901cf4cebbeaebec514d"), "Name" : "David", "Age" : 23 }
{ "_id" : ObjectId("5e419015f4cebbeaebec514c"), "Name" : "Chris", "Age" : 21 }
{ "_id" : ObjectId("5e419023f4cebbeaebec514e"), "Name" : "Bob", "Age" : 24 }

更新於:30-Mar-2020

191 次瀏覽

開啟你的 職業生涯

透過完成課程獲得認證

立即開始學習
廣告