Mongoose Aggregate.prototype.sort()函数
Aggregate sort() 方法是Mongoose API的一部分,用于执行聚合任务。它允许我们根据提供的字段对集合中的所有文档进行排序。它还提供了按升序或降序对输入文档进行排序的灵活性。
语法:
aggregate().sort( { fieldName : sortOrder } )
参数: 此方法接受一个参数,如下所述:
- string/object: 用于指定集合中字段的名称。我们可以以字符串格式或作为对象提供字段名称,并指定排序顺序。
返回值: 此方法以数组形式返回结果集。
设置Node.js Mongoose模块:
步骤1: 使用以下命令创建一个Node.js应用程序:
npm init
步骤2:创建NodeJS应用程序之后,使用以下命令安装所需的模块:
npm install mongoose
项目结构: 项目的结构将如下所示:
数据库结构:
数据库结构将会是这样的,该集合中包含以下文档。
示例1: 在这个示例中,我们使用mongoose建立了一个数据库连接,并定义了一个userSchema模型,包含两个字段”name”和”bornYear”。最后,我们使用sort()方法按照bornYear字段的升序对结果集进行排序。要按照升序排序,我们需要将bornYear字段的值设为”1″,要按照降序排序,值字段的值应为”-1″。
文件名:app.js
// Require mongoose module
const mongoose = require("mongoose");
// Set Up the Database connection
mongoose.connect("mongodb://localhost:27017/geeksforgeeks", {
useNewUrlParser: true,
useUnifiedTopology: true,
});
const userSchema = new mongoose.Schema({
name: String,
bornYear: Number
});
const User = mongoose.model('User', userSchema);
User.aggregate().sort({ 'bornYear': 1 })
.then(result => {
console.log(result)
})
运行程序的步骤: 在项目的根目录中执行以下命令来运行应用程序:
node app.js
输出:
[
{
_id: new ObjectId("6387aa99c92df30f995e8309"),
name: 'Aakash',
bornYear: 2000,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830a"),
name: 'Ayush',
bornYear: 2000,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830b"),
name: 'Rahul',
bornYear: 2000,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830e"),
name: 'Takshwi',
bornYear: 2018,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830c"),
name: 'Mivan',
bornYear: 2019,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830d"),
name: 'Sidiksha',
bornYear: 2019,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830f"),
name: 'Kashwi',
bornYear: 2021,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e8310"),
name: 'Kinjal',
bornYear: 2021,
__v: 0
}
]
示例2: 在该示例中,我们使用了通过传递对象数组参数来使用pipeline对象。首先,我们按照bornYear字段按降序进行排序,然后按照name字段按升序进行排序。
文件名:app.js
// Require mongoose module
const mongoose = require("mongoose");
// Set Up the Database connection
mongoose.connect("mongodb://localhost:27017/geeksforgeeks", {
useNewUrlParser: true,
useUnifiedTopology: true,
});
const userSchema = new mongoose.Schema({
name: String,
bornYear: Number
});
const User = mongoose.model('User', userSchema);
User.aggregate([{ $sort: { bornYear: -1, name: 1 } }])
.exec((error, result) => {
if (error) {
console.log(error)
} else {
console.log(result)
}
})
运行程序的步骤: 在项目的根目录中,执行以下命令来运行应用程序:
node app.js
输出:
[
{
_id: new ObjectId("6387aa99c92df30f995e830f"),
name: 'Kashwi',
bornYear: 2021,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e8310"),
name: 'Kinjal',
bornYear: 2021,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830c"),
name: 'Mivan',
bornYear: 2019,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830d"),
name: 'Sidiksha',
bornYear: 2019,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830e"),
name: 'Takshwi',
bornYear: 2018,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e8309"),
name: 'Aakash',
bornYear: 2000,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830a"),
name: 'Ayush',
bornYear: 2000,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830b"),
name: 'Rahul',
bornYear: 2000,
__v: 0
}
]
参考: https://mongoosejs.com/docs/api/aggregate.html#aggregate_Aggregate-sort