當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


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。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。