如何在 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 }
廣告
資料結構
網路
關係型資料庫管理系統
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP