Mongoose API 的 Aggregate sort() 方法用于执行聚合任务。它允许我们根据我们提供的字段对集合中的所有文档进行排序。它还为我们提供了按升序或降序对输入文档进行排序的灵活性。
用法:
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()方法 对结果集进行排序出生年份按升序排列。要按升序排序,我们必须提供 “1” 作为值出生年份字段并按降序排序值字段值应为“-1”。
文件名:app.js
Javascript
// 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:在此示例中,我们通过传递对象数组参数来使用管道对象。首先我们进行排序出生年份字段按降序排列,然后进行排序名字字段按升序排列。
文件名:app.js
Javascript
// 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
相关用法
- Mongoose Aggregate.prototype.sortByCount()用法及代码示例
- Mongoose Aggregate.prototype.skip()用法及代码示例
- Mongoose Aggregate.prototype.catch()用法及代码示例
- Mongoose Aggregate.prototype.exec()用法及代码示例
- Mongoose Aggregate.prototype.model()用法及代码示例
- Mongoose Aggregate.prototype.limit()用法及代码示例
- Mongoose Aggregate.prototype.then()用法及代码示例
- Mongoose Aggregate.prototype.append()用法及代码示例
- Mongoose Aggregate.prototype.project()用法及代码示例
- Mongoose Aggregate.prototype.pipeline()用法及代码示例
- Mongoose Aggregate.prototype.match()用法及代码示例
- Mongoose Aggregate.prototype.cursor()用法及代码示例
- Mongoose Aggregate.prototype.addFields()用法及代码示例
- Mongoose Aggregate.prototype.lookup()用法及代码示例
- Mongoose Aggregate prototype.unionWith()用法及代码示例
- Mongoose Aggregate prototype.sample()用法及代码示例
- Mongoose Aggregate prototype.unwind()用法及代码示例
- Mongoose countDocuments()用法及代码示例
- Mongoose deleteMany()用法及代码示例
- Mongoose deleteOne()用法及代码示例
- Mongoose estimatedDocumentCount()用法及代码示例
- Mongoose exists()用法及代码示例
- Mongoose find()用法及代码示例
- Mongoose findById()用法及代码示例
- Mongoose findByIdAndDelete()用法及代码示例
注:本文由纯净天空筛选整理自sakshio0hoj大神的英文原创作品 Mongoose Aggregate.prototype.sort() API。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。