Mongoose Aggregate.prototype.project()函数

Mongoose Aggregate.prototype.project()函数

聚合类型 API.prototype.project() Mongoose API 的方法用于执行聚合任务。它允许我们从集合中选择字段。使用此方法,我们可以请求从集合中提取选定的字段到结果集中。如果您不希望结果集中包含集合中的所有字段,可以使用 project() 请求指定的字段包含在结果集中。总的来说,我们可以为结果集指定包含和排除的字段。

语法:

aggregate().project( specifications )
JavaScript

参数: 此方法接受一个参数,如下所述:

  • 对象/字符串: 它用于指定您希望包含和排除在结果集中的字段。

返回值: 此方法以数组形式返回结果集。

设置Node.js Mongoose模块:

步骤1: 使用以下命令创建一个Node.js应用程序:

npm init
JavaScript

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

npm install mongoose
JavaScript

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

Mongoose Aggregate.prototype.project()函数

数据库结构: 数据库结构将如下所示,集合中包含以下文档。

Mongoose Aggregate.prototype.project()函数

示例1: 在该示例中,我们使用mongoose建立了一个数据库连接,并在userSchema上定义了一个模型,该模型具有三个列或字段“_id”,“name”“bornYear”。最后,我们通过对象形式将specification传递给project()方法。在这个示例中,我们希望在结果集中包含_id和name。这就是为什么我们将它们的值都设置为1的原因。如果您不希望将任何字段包含在结果集中,则要么不在specifications中提及它,要么将其赋值为0。

文件名:app.js

// Require mongoose module 
const mongoose = require("mongoose"); 
  
// Set Up the Database connection 
mongoose.connect("mongodb://localhost:27017/geeksforgeeks", { 
    useNewUrlParser: true, 
    useUnifiedTopology: true, 
}); 
  
const userSchema = new mongoose.Schema({ 
    name: String, 
    bornYear: Number 
}); 
  
const User = mongoose.model('User', userSchema); 
  
User.aggregate() 
    .project({ _id: 1, name: 1 }) 
    .then((result, error) => { 
        if (result) 
            console.log(result); 
        else
            console.log(error) 
    })
JavaScript

运行程序的步骤: 从项目的根目录执行以下命令来运行应用程序:

node app.js
JavaScript

输出:

[
  { _id: new ObjectId("6387aa99c92df30f995e8309"), name: 'Aakash' },  
  { _id: new ObjectId("6387aa99c92df30f995e830a"), name: 'Ayush' },   
  { _id: new ObjectId("6387aa99c92df30f995e830b"), name: 'Rahul' },   
  { _id: new ObjectId("6387aa99c92df30f995e830c"), name: 'Mivan' },   
  { _id: new ObjectId("6387aa99c92df30f995e830d"), name: 'Sidiksha' },
  { _id: new ObjectId("6387aa99c92df30f995e830e"), name: 'Takshwi' }, 
  { _id: new ObjectId("6387aa99c92df30f995e830f"), name: 'Kashwi' },  
  { _id: new ObjectId("6387aa99c92df30f995e8310"), name: 'Kinjal' }   
]
JavaScript

示例2: 在这个示例中,我们使用mongoose建立了数据库连接,并在userSchema上定义了模型,有三个列或字段“_id”,“name”“bornYear”,我们在User模型上调用了aggregate()方法。在这个示例中,我们只想将bornYear字段包含在结果集中。这就是为什么我们给bornYear字段分配了1,并给_id分配了0。我们没有提到name字段,所以它将自动被认为是结果集中独有的。

文件名:app.js

// Require mongoose module 
const mongoose = require("mongoose"); 
  
// Set Up the Database connection 
mongoose.connect("mongodb://localhost:27017/geeksforgeeks", { 
    useNewUrlParser: true, 
    useUnifiedTopology: true, 
}); 
  
const userSchema = new mongoose.Schema({ 
    name: String, 
    bornYear: Number 
}); 
  
const User = mongoose.model('User', userSchema); 
  
User.aggregate([{ $project: { _id: 0, bornYear: 1 } }]) 
    .exec((error, result) => { 
        if (error) { 
            console.log(error); 
        } else { 
            console.log(result); 
        } 
    })
JavaScript

运行程序的步骤: 要运行该应用程序,请在项目的根目录下执行以下命令:

node app.js
JavaScript

输出:

[
  { bornYear: 2000 },
  { bornYear: 2000 },
  { bornYear: 2000 },
  { bornYear: 2019 },
  { bornYear: 2019 },
  { bornYear: 2018 },
  { bornYear: 2021 },
  { bornYear: 2021 } 
]
JavaScript

参考资料: https://mongoosejs.com/docs/api/aggregate.html#aggregate_Aggregate-project

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程

登录

注册