Mongoose Query.prototype.in()函数
Mongoose Query.prototype.in()方法用于扫描集合中的所有文档,并返回那些路径值位于传递给该方法参数的数组中的文档。
语法
Query.prototype.in(path, val)
参数: 此API接受上述所述并描述如下的以下参数:
- path: 字符串,用于标识mongoose模式中的属性名称
- val: 数组,确定要扫描的值范围,并查找所有路径具有值位于数组中的文档
返回类型: 返回一个查询对象作为响应。
创建Node应用并安装Mongoose:
步骤1: 使用以下命令创建一个Node应用程序:
mkdir folder_name
cd folder_name
npm init -y
touch main.js
步骤2: 完成 Node.js 应用程序后,请使用以下命令安装所需的模块:
npm install mongoose
示例1: 在这个例子中,我们将使用这种方法来返回年龄在“[35, 40]”范围内的文档。
文件名: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 () => {
await Person.insertMany(personsArray)
const res = await Person.find().in('age', [35, 40])
console.log({ res });
})();
运行应用程序的步骤: 从项目的根目录下使用以下命令运行应用程序:
node main.js
输出 :
使用MongoDB Compass的数据库的GUI表示:
示例2: 在这个示例中,我们将使用这种方法来返回名字在值”[“Zoro”, “Usorp”]”中的文档。
文件名: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 () => {
await Person.insertMany(personsArray)
const res = await Person.find().in(
'name', ['Zoro', 'Usorp']
)
console.log({ res });
})();
运行应用程序的步骤: 从项目的根目录中使用以下命令运行应用程序:
node main.js
输出:
使用MongoDB Compass图形界面表示的数据库:
参考: https://mongoosejs.com/docs/api/query.html#query_Query-in