Mongoose Aggregate.prototype.skip()函数
Aggregate API.prototype.skip()方法用于执行聚合任务。它允许我们跳过集合中指定数量的文档对象,并将剩余的文档传递给管道的下一个阶段和结果集。
语法:
aggregate().skip( number )
参数: 此方法接受一个参数,如下所述:
- number: 用于指定要跳过的文档数量。
返回值: 此方法以数组形式返回结果集。
设置Node.js Mongoose模块:
步骤1: 使用以下命令创建一个Node.js应用程序:
npm init
步骤2: 创建NodeJS应用程序后,使用以下命令安装所需模块:
npm install mongoose
项目结构: 项目的结构将如下所示:
数据库结构: 数据库结构将会如下所示,集合中包含以下文档。
示例1: 在这个示例中,我们使用mongoose建立了一个数据库连接,并在userSchema上定义了模型,其中有两个列或字段 “name” 和 “bornYear”。最后,我们调用 skip() 并将“5”作为参数传递给它,以跳过集合中的前5个文档,并获取结果集中的剩余3个文档。
文件名: 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().skip(5)
.then((successCb, errorCb) => {
if (successCb) {
console.log(successCb);
} else {
console.log(errorCb);
}
})
运行程序的步骤: 从项目的根目录下执行以下命令来运行应用程序:
node app.js
输出:
[
{
_id: new ObjectId("6387aa99c92df30f995e830e"),
name: 'Takshwi',
bornYear: 2018,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e830f"),
name: 'Kashwi',
bornYear: 2021,
__v: 0
},
{
_id: new ObjectId("6387aa99c92df30f995e8310"),
name: 'Kinjal',
bornYear: 2021,
__v: 0
}
]
示例2: 在这个示例中,我们使用mongoose建立了一个数据库连接,定义了基于userSchema的模型,其中有两个字段“name”和“bornYear”。最后,我们在User模型上调用 aggregate() 方法,并将管道对象作为数组传递进去,以跳过8条记录中的前7条记录。在输出中,我们得到了跳过前7条记录后,集合中的单个最后一个文档。
文件名: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([{ $skip: 7 }])
.exec((error, success) => {
if (error) {
console.log(error);
} else {
console.log(success);
}
})
运行程序的步骤: 从项目的根目录执行以下命令来运行应用程序:
node app.js
输出:
[
{
_id: new ObjectId("6387aa99c92df30f995e8310"),
name: 'Kinjal',
bornYear: 2021,
__v: 0
}
]
参考: https://mongoosejs.com/docs/api/aggregate.html#aggregate_Aggregate-skip