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


Mongoose Document Model.where()用法及代码示例


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



相关用法


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