Mongoose API 的 Model.where() 方法用于根据条件从集合中提取文档。我们可以在任何模型上直接使用where(),在where()上我们可以输入各种关系条件来获得结果。 Model.where() 返回对象数组。每个对象都由集合中的文档组成。
设置 Node.js 应用程序:
步骤 1:使用以下命令创建 Node.js 应用程序:
npm init
步骤 2:创建 NodeJS 应用程序后,使用以下命令安装所需的模块:
npm install mongoose
项目结构: 项目结构将如下所示:
示例 1:在此示例中,我们使用 mongoose 建立了数据库连接,并通过 customerSchema 定义了模型,具有两列 “name” 和 “orderCount”。最后,我们在 Customer 模型上使用 where 方法,它将根据我们提供的条件为我们提供一个对象数组。在此示例中,我们查找 “orderCount” 值大于 10 的文档。
- 应用程序.js:在app.js 文件中写入以下代码:
Javascript
// Require mongoose module
const mongoose = require('mongoose');
// Set Up the Database connection
mongoose.connect(
'mongodb://localhost:27017/geeksforgeeks', {
useNewUrlParser: true,
useUnifiedTopology: true
})
// Defining customerSchema schema
const customerSchema = new mongoose.Schema(
{ name: String, orderCount: Number }
)
// Defining customerSchema model
const Customer = mongoose.model('Customer', customerSchema);
Customer.where('orderCount').gt(10).then(result => {
console.log(result)
});
运行程序的步骤: 要运行应用程序,请从项目的根目录执行以下命令:
node app.js
输出:
[ { _id: new ObjectId("6304e7c8c21ca86f5ea6fce4"), name: 'Customer3', orderCount: 20, __v: 0 } ]
示例 2:在此示例中,我们查找 “orderCount” 值大于 5 且小于 20 的文档。
- 应用程序.js:在app.js 文件中写入以下代码:
Javascript
// Require mongoose module
const mongoose = require('mongoose');
// Set Up the Database connection
mongoose.connect(
'mongodb://localhost:27017/geeksforgeeks', {
useNewUrlParser: true,
useUnifiedTopology: true
})
// Defining customerSchema schema
const customerSchema = new mongoose.Schema(
{ name: String, orderCount: Number }
)
// Defining customerSchema model
const Customer = mongoose.model('Customer', customerSchema);
Customer.where('orderCount').gt(5).lt(20).then(result => {
console.log(result)
});
运行程序的步骤: 要运行应用程序,请从项目的根目录执行以下命令:
node app.js
输出:
[ { _id: new ObjectId("6304e7c8c21ca86f5ea6fce3"), name: 'Customer2', orderCount: 10, __v: 0 }, { _id: new ObjectId("6305fa9f63f7ccbdbc0ee95c"), name: 'Customer3', orderCount: 10, __v: 0 }, { _id: new ObjectId("6305fa9f63f7ccbdbc0ee95d"), name: 'Customer4', orderCount: 10, __v: 0 } ]
参考:https://mongoosejs.com/docs/api/model.html#model_Model-where
相关用法
- Mongoose Document Model.create()用法及代码示例
- Mongoose Document Model.deleteOne()用法及代码示例
- Mongoose Document Model.updateOne()用法及代码示例
- Mongoose Document Model.countDocuments()用法及代码示例
- Mongoose Document Model.populate()用法及代码示例
- Mongoose Document Model.replaceOne()用法及代码示例
- Mongoose Document Model.inspect()用法及代码示例
- Mongoose Document Model.prototype.model()用法及代码示例
- Mongoose Document Model.listIndexes()用法及代码示例
- Mongoose Document Model.estimatedDocumentCount()用法及代码示例
- Mongoose Document Model.updateMany()用法及代码示例
- Mongoose Document Model.prototype.deleteOne()用法及代码示例
- Mongoose Document Model.init()用法及代码示例
- Mongoose Document Model.prototype.remove()用法及代码示例
- Mongoose Document Model.remove()用法及代码示例
- Mongoose Document Model.prototype.save()用法及代码示例
- Mongoose Document Model.deleteMany()用法及代码示例
- Mongoose Document Model.exists()用法及代码示例
- Mongoose Document Model.insertMany()用法及代码示例
- Mongoose Document Model.count()用法及代码示例
- Mongoose Document Model.bulkWrite()用法及代码示例
- Mongoose Document prototype.getChanges()用法及代码示例
- Mongoose Document prototype.unmarkModified()用法及代码示例
- Mongoose Document prototype.replaceOne()用法及代码示例
- Mongoose Document prototype.get()用法及代码示例
注:本文由纯净天空筛选整理自kartikmukati大神的英文原创作品 Mongoose Document Model.where() API。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。