Mongoose Query.prototype.where()函数

Mongoose Query.prototype.where()函数

Mongoose是一个用于node.js环境的MongoDB对象建模和处理工具。Mongoose查询 where()方法 用于使用MongoDB查询系统从集合中过滤文档。它可以通过链接或传递查询条件的方式进行使用。让我们通过一些示例来更好地理解它。

语法:

Query.prototype.where()

参数: 它接受下面描述的2个参数::

  • path: 它是String或Object类型。
  • val: 它可以是任意类型。

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

创建节点应用并安装Mongoose:

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

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

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

npm install mongoose

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

Mongoose Query.prototype.where()函数

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

Mongoose Query.prototype.where()函数

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

文件名: 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: '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

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

Mongoose Query.prototype.where()函数

GUI 表示使用 MongoDB Compass 的数据库:

Mongoose Query.prototype.where()函数

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

文件名: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: '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

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

Mongoose Query.prototype.where()函数

使用MongoDB Compass的GUI表示数据库:

Mongoose Query.prototype.where()函数

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

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程