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


Mongoose Aggregate.prototype.addFields()用法及代碼示例


Mongoose API 的 Aggregate API.prototype.addFields() 方法用於執行聚合任務。它允許我們向輸出文檔添加新字段。使用addFields()方法,我們可以將自定義字段與現有字段一起添加到結果集中,並可以在輸出文檔中看到它們。

用法:

aggregate(.....).addFields( Object )

Parameters: 此方法接受單個參數,如下所述:

  • Object: 該對象將用於指定我們想要包含在結果集中的新字段。

返回值:該方法以數組的形式返回結果集。

設置 Node.js Mongoose 模塊:

步驟 1:使用以下命令創建 Node.js 應用程序:

npm init

步驟 2:創建 NodeJS 應用程序後,使用以下命令安裝所需的模塊:

npm install mongoose

項目結構: 項目結構將如下所示:

數據庫結構:數據庫結構如下所示,集合中存在以下文檔。

示例 1:在此示例中,我們使用 mongoose 建立了數據庫連接,並通過 userSchema 定義了模型,具有五個列或字段 “_id”、“name”、“fixedDeposit”、“interest” 和 “tenure”。最後,我們呼籲addFields()方法並將一個新字段與現有字段一起添加到輸出文檔中。新字段的名稱是投資返回該字段通過本金、利率和期限相乘來計算投資返回率。

文件名: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, 
}); 
  
const userSchema = new mongoose.Schema({ 
    name: String, 
    fixedDeposit: Number, 
    interest: Number, 
    tenure: Number 
}); 
  
const User = mongoose.model('User', userSchema); 
  
User.aggregate() 
    .project({ name: 1, fixedDeposit: 1, interest: 1, tenure: 1 }) 
    .addFields({ 
        returnOnInvestment: { 
            $multiply: ["$fixedDeposit", "$interest", "$tenure"] 
        } 
    }).then(result => { 
        console.log(result) 
    })

運行程序的步驟:要運行應用程序,請從項目的根目錄執行以下命令:

node app.js

輸出:

[
  {
    _id: new ObjectId("638f0262cc8a382bcf3d93df"),
    name: 'Bhavesh',
    fixedDeposit: 8000,
    interest: 0.03,
    tenure: 60,
    investmentReturn: 14400
  },
  {
    _id: new ObjectId("638f0262cc8a382bcf3d93de"),
    name: 'Aditya',
    fixedDeposit: 50000,
    interest: 0.04,
    tenure: 24,
    investmentReturn: 48000
  }
]

示例 2:在此示例中,我們使用 mongoose 建立了數據庫連接,並通過 userSchema 定義了模型,具有五個列或字段 “_id”、“name”、“fixedDeposit”、“interest” 和 “tenure”。最後,我們呼籲addFields()方法並將一個新字段與現有字段一起添加到輸出文檔中。新字段的名稱是一個月返回該字段計算的是一個月的投資返回率,本金、利率乘以1。

文件名: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, 
}); 
  
const userSchema = new mongoose.Schema({ 
    name: String, 
    fixedDeposit: Number, 
    interest: Number, 
    tenure: Number 
}); 
  
const User = mongoose.model('User', userSchema); 
  
User.aggregate([{ 
    $project: 
        { name: 1, fixedDeposit: 1, interest: 1, tenure: 1 } 
}]) 
    .addFields({ 
        oneMonthReturn: 
            { $multiply: ["$fixedDeposit", "$interest", 1] } 
    }).exec((error, success) => { 
        if (error) 
            console.log(error); 
        else
            console.log(success); 
    })

運行程序的步驟:要運行應用程序,請從項目的根目錄執行以下命令:

node app.js

輸出:

[
 {
   _id: new ObjectId("638f0262cc8a382bcf3d93df"),
   name: 'Bhavesh',
   fixedDeposit: 8000,
   interest: 0.03,
   tenure: 60,
   oneMonthReturn: 240
 },
 {
   _id: new ObjectId("638f0262cc8a382bcf3d93de"),
   name: 'Aditya',
   fixedDeposit: 50000,
   interest: 0.04,
   tenure: 24,
   oneMonthReturn: 2000
 }
]

參考: https://mongoosejs.com/docs/api/aggregate.html#aggregate_Aggregate-addFields



相關用法


注:本文由純淨天空篩選整理自sakshio0hoj大神的英文原創作品 Mongoose Aggregate.prototype.addFields() API。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。