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


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


Mongoose 是针对 node.js 环境的 MongoDB 对象建模和处理。 Mongoose Query where() 方法用于使用 MongoDB 查询系统从集合中过滤文档。它可以以多种方式使用,例如链接或传递查询条件。让我们通过一些例子来更多地了解这一点。

用法:

Query.prototype.where()

Parameters: 它接受如下所述的 2 个参数:

  • path:它的类型为 String 或 Object。
  • val:它可以是任何类型。

返回类型:它返回查询对象。

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

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

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

步骤 2:创建 ReactJS 应用程序后,使用以下命令安装所需的模块:

npm install mongoose

项目结构: 它将如下所示。

使用 MongoDB Compass 的数据库的 GUI 表示:目前,该集合没有数据。

示例 1:在这个例子中,我们将使用查询where()方法使用链接方法过滤出文档,我们将不同的查询链接在一起。

文件名:main.js

Javascript


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: 'John', 
        age: 22 
    }, 
    { 
        name: 'Dave', 
        age: 17 
    }, 
    { 
        name: 'Earl', 
        age: 12 
    } 
] 
  
const Person = mongoose.model('Person', personSchema); 
  
(async () => { 
    await Person.insertMany(personsArray); 
    const persons =  
        await Person.find().where('age').gte(18); 
    console.log(persons); 
})()

运行应用程序的步骤:从项目的根目录使用以下命令运行应用程序:

node main.js

输出:我们看到结果中的值保持不变。

使用 MongoDB 指南针的数据库的 GUI 表示:

示例 2:在这个例子中,我们将使用查询APIwhere()方法通过将查询条件作为参数传递给 where() 方法来过滤文档。

文件名:main.js

Javascript


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: 'John', 
        age: 22 
    }, 
    { 
        name: 'Dave', 
        age: 17 
    }, 
    { 
        name: 'Earl', 
        age: 12 
    } 
] 
  
const Person = mongoose.model('Person', personSchema); 
  
(async () => { 
    await Person.insertMany(personsArray); 
    const persons = await Person.find().where 
        ({ age: { $lte: 18 } }) 
    console.log(persons); 
})()

运行应用程序的步骤:从项目的根目录使用以下命令运行应用程序:

node main.js

输出:我们看到结果中的值保持不变。

使用 MongoDB 指南针的数据库的 GUI 表示:

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



相关用法


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