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
相關用法
- Mongoose Query prototype.transform()用法及代碼示例
- Mongoose Query prototype.size()用法及代碼示例
- Mongoose Query prototype.selectedExclusively()用法及代碼示例
- Mongoose Query prototype.selectedInclusively()用法及代碼示例
- Mongoose Query prototype.selected()用法及代碼示例
- Mongoose Query prototype.skip()用法及代碼示例
- Mongoose Query prototype.slice()用法及代碼示例
- Mongoose Query prototype.all()用法及代碼示例
- Mongoose Query prototype.sort()用法及代碼示例
- Mongoose Query API.prototype.getOptions()用法及代碼示例
- Mongoose Query API.prototype.getUpdate()用法及代碼示例
- Mongoose Query API.prototype.writeConcern()用法及代碼示例
- Mongoose Query API.prototype.getFilter()用法及代碼示例
- Mongoose Query.prototype.all()用法及代碼示例
- Mongoose Query.prototype.and()用法及代碼示例
- Mongoose Query.prototype.batchSize()用法及代碼示例
- Mongoose Query.prototype.box()用法及代碼示例
- Mongoose Query.prototype.catch()用法及代碼示例
- Mongoose Query.prototype.centerSphere()用法及代碼示例
- Mongoose Query.prototype.circle()用法及代碼示例
- Mongoose Query.prototype.collation()用法及代碼示例
- Mongoose Query.prototype.cursor()用法及代碼示例
- Mongoose Query.prototype.distinct()用法及代碼示例
- Mongoose Query.prototype.exec()用法及代碼示例
- Mongoose Query.prototype.explain()用法及代碼示例
注:本文由純淨天空篩選整理自dishebhbhayana大神的英文原創作品 Mongoose Query prototype.where() API。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。