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
相關用法
- Mongoose Aggregate.prototype.append()用法及代碼示例
- Mongoose Aggregate.prototype.catch()用法及代碼示例
- Mongoose Aggregate.prototype.exec()用法及代碼示例
- Mongoose Aggregate.prototype.model()用法及代碼示例
- Mongoose Aggregate.prototype.skip()用法及代碼示例
- Mongoose Aggregate.prototype.limit()用法及代碼示例
- Mongoose Aggregate.prototype.then()用法及代碼示例
- Mongoose Aggregate.prototype.sortByCount()用法及代碼示例
- Mongoose Aggregate.prototype.project()用法及代碼示例
- Mongoose Aggregate.prototype.pipeline()用法及代碼示例
- Mongoose Aggregate.prototype.match()用法及代碼示例
- Mongoose Aggregate.prototype.cursor()用法及代碼示例
- Mongoose Aggregate.prototype.sort()用法及代碼示例
- Mongoose Aggregate.prototype.lookup()用法及代碼示例
- Mongoose Aggregate prototype.unionWith()用法及代碼示例
- Mongoose Aggregate prototype.sample()用法及代碼示例
- Mongoose Aggregate prototype.unwind()用法及代碼示例
- Mongoose countDocuments()用法及代碼示例
- Mongoose deleteMany()用法及代碼示例
- Mongoose deleteOne()用法及代碼示例
- Mongoose estimatedDocumentCount()用法及代碼示例
- Mongoose exists()用法及代碼示例
- Mongoose find()用法及代碼示例
- Mongoose findById()用法及代碼示例
- Mongoose findByIdAndDelete()用法及代碼示例
注:本文由純淨天空篩選整理自sakshio0hoj大神的英文原創作品 Mongoose Aggregate.prototype.addFields() API。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。