当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Mongoose Query.prototype.in()用法及代码示例


Mongoose 查询 API in() 方法用于扫描集合中的所有文档,并返回路径值位于方法参数中传递的数组中的文档。

用法

Query.prototype.in(path, val)

参数:它接受如上所述和如下所述的以下参数:

  • path:它是一个字符串,标识 mongoose schema 中的属性名称
  • val:它是一个数组,用于确定要扫描的值的范围并查找其路径具有位于数组中的值的所有文档

返回类型:它返回一个 Query 对象作为响应。

创建节点应用程序并安装 Mongoose:

步骤1:使用以下命令创建节点应用程序:

mkdir folder_name
cd folder_name
npm init -y
touch main.js

步骤 2:完成 Node.js 应用程序后,使用以下命令安装所需的模块:

npm install mongoose

示例 1:在此示例中,我们将使用此方法返回年龄位于值“[35, 40]”内的文档

文件名:main.js

Javascript


//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 指南针的数据库的 GUI 表示:

示例 2:在此示例中,我们将使用此方法返回名称位于值 “[“Zoro”、“Usorp”]” 中的文档

文件名:main.js

Javascript


//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 指南针的数据库的 GUI 表示:

参考: https://mongoosejs.com/docs/api/query.html#query_Query-in



相关用法


注:本文由纯净天空筛选整理自dishebhbhayana大神的英文原创作品 Mongoose Query.prototype.in() API。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。