如何使用 MongoDB 聚合进行排序?


使用 aggregate(),并在其中使用 $sort 对 MongoDB 进行排序。让我们创建一个包含文档的集合 -

> db.demo164.insertOne({"StudentAge":24});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e36883d9e4f06af551997c8")
}
> db.demo164.insertOne({"StudentAge":25});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e3688409e4f06af551997c9")
}
> db.demo164.insertOne({"StudentAge":22});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e3688429e4f06af551997ca")
}
> db.demo164.insertOne({"StudentAge":21});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e3688439e4f06af551997cb")
}

使用 find() 方法从集合中显示所有文档 -

> db.demo164.find();

这将生成以下输出 -

{ "_id" : ObjectId("5e36883d9e4f06af551997c8"), "StudentAge" : 24 }
{ "_id" : ObjectId("5e3688409e4f06af551997c9"), "StudentAge" : 25 }
{ "_id" : ObjectId("5e3688429e4f06af551997ca"), "StudentAge" : 22 }
{ "_id" : ObjectId("5e3688439e4f06af551997cb"), "StudentAge" : 21 }

以下是使用 MongoDB aggregate() 的查询 -

> db.demo164.aggregate([{ $sort : { StudentAge : -1 } }]);

这将生成以下输出 -

{ "_id" : ObjectId("5e3688409e4f06af551997c9"), "StudentAge" : 25 }
{ "_id" : ObjectId("5e36883d9e4f06af551997c8"), "StudentAge" : 24 }
{ "_id" : ObjectId("5e3688429e4f06af551997ca"), "StudentAge" : 22 }
{ "_id" : ObjectId("5e3688439e4f06af551997cb"), "StudentAge" : 21 }

更新于:01-4月-2020

159 视图

开启你的 职业生涯

完成该课程获得认证

开始
广告