Mongoose Query.prototype.post()函数
Mongoose Query API post() 方法用于向mongoose查询实例添加后置中间件,可用于执行查询后的操作。
语法:
Query.prototype.post(fn)
参数: 它接受上述提及并以下述方式描述的参数:
- fn: 这是一个中间件函数,用于执行查询之后的操作
返回类型: 它返回一个作为响应的查询对象。
创建Node.js应用并安装Mongoose:
步骤1: 使用以下命令创建一个Node.js应用:
mkdir folder_name
cd folder_name
npm init -y
touch main.js
步骤2: 完成Node.js应用程序后,使用以下命令安装所需模块:
npm install mongoose
示例 1: 在这个示例中,我们将使用这种方法将查询过滤器日志记录到控制台。
文件名: main.js
// Importing the module
const mongoose = require('mongoose')
// Creating the 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'));
let personSchema = new mongoose.Schema({
name: {
type: String,
},
age: {
type: Number,
}
});
let personsArray = [
{
name: 'Luffy',
age: 20
},
{
name: 'Nami',
age: 20,
},
{
name: 'Zoro',
age: 35
}
]
let Person = mongoose.model('Person', personSchema);
(async () => {
let query = Person.find({ age: 20 })
query.pre(function middleware() {
console.log(this.getFilter());
})
await query.exec()
})();
运行应用程序的步骤: 从项目的根目录使用以下命令运行应用程序:
node main.js
输出:
示例2: 在这个示例中,我们将使用此方法将整个查询记录到控制台。
文件名: main.js
// Importing the module
const mongoose = require('mongoose')
// Creating the 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'));
let personSchema = new mongoose.Schema({
name: {
type: String,
},
age: {
type: Number,
}
});
let personsArray = [
{
name: 'Luffy',
age: 20
},
{
name: 'Nami',
age: 20,
},
{
name: 'Zoro',
age: 35
}
]
let Person = mongoose.model('Person', personSchema);
(async () => {
let query = Person.find({ name: 'Luffy' })
.where('age').equals(20)
query.pre(function middleware() {
console.log(this.getQuery());
})
await query.exec()
})();
运行应用程序的步骤: 从项目的根目录执行以下命令来运行应用程序:
node main.js
输出:
参考: https://mongoosejs.com/docs/api/query.html#query_Query-post