Computer >> Máy Tính >  >> Lập trình >> MongoDB

Làm cách nào để sắp xếp, chọn và truy vấn tài liệu con trong MongoDB?

Để sắp xếp, hãy sử dụng $ sort trong MongoDB. Hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -

> 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")
}

Hiển thị tất cả các tài liệu từ một bộ sưu tập với sự trợ giúp của phương thức find () -

> db.demo236.find();

Điều này sẽ tạo ra kết quả sau -

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

Sau đây là truy vấn để sắp xếp, chọn và truy vấn tài liệu con trong MongoDB -

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

Điều này sẽ tạo ra kết quả sau -

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