Mongoose Query.prototype.limit()函数
使用 Mongoose 查询 API limit() 方法 限制查询 API 返回的文档数量为指定的计数。
语法:
Query.prototype.limit(val)
参数: 接受一个参数,如下所述:
- val: 这是一个数字,确定查询API将返回的最大文档数。
返回类型: 它以一个Query对象的形式作为响应返回。
创建Node应用程序和安装Mongoose:
步骤1: 使用以下命令创建一个Node应用程序:
mkdir folder_name
cd folder_name
npm init -y
touch main.js
步骤2: 完成Node.js应用程序后,使用以下命令安装所需的模块:
npm install mongoose
示例1: 在这个示例中,我们将使用这种方法返回一个年龄大于“18”的几乎1个文档。
文件名:main.js
const mongoose = require('mongoose')
// Database connection
mongoose.connect('mongodb://localhost:27017/query-helpers',
{
dbName: 'event_db',
useNewUrlParser: true,
useUnifiedTopology: true
}, err => err ? console.log(err)
: console.log('Connected to database'));
const personSchema = new mongoose.Schema({
name: {
type: String,
},
age: {
type: Number,
}
});
const personsArray = [
{
name: 'Luffy',
age: 19
},
{
name: 'Nami',
age: 20,
},
{
name: 'Zoro',
age: 35
}
]
const Person = mongoose.model('Person', personSchema);
(async () => {
await Person.insertMany(personsArray);
const res = await Person.where(
{ age: { $gt: 18 } }
).limit(1);
console.log({ res });
})()
运行应用的步骤: 从项目的根目录下使用以下命令运行应用:
node main.js
输出:
使用MongoDB Compass的数据库的GUI表示形式:
示例2: 在这个示例中,我们将使用这种方法返回所有年龄大于“18”的文档。
文件名:main.js
const mongoose = require('mongoose')
// Database connection
mongoose.connect('mongodb://localhost:27017/query-helpers',
{
dbName: 'event_db',
useNewUrlParser: true,
useUnifiedTopology: true
}, err => err ? console.log(err)
: console.log('Connected to database'));
const personSchema = new mongoose.Schema({
name: {
type: String,
},
age: {
type: Number,
}
});
const personsArray = [
{
name: 'Luffy',
age: 19
},
{
name: 'Nami',
age: 20,
},
{
name: 'Zoro',
age: 35
}
]
const Person = mongoose.model('Person', personSchema);
(async () => {
await Person.insertMany(personsArray);
const res = await Person.where(
{ age: { $gt: 18 } }
).limit();
console.log({ res });
})()
运行应用程序的步骤 :从项目的根目录使用以下命令来运行应用程序:
node main.js
输出:
MongoDB Compass的GUI表示数据库的图形化界面:
参考: https://mongoosejs.com/docs/api/query.html#query_Query-limit