gpt4 book ai didi

node.js - Node js、Mongoose计算总和并返回多个字段

转载 作者:太空宇宙 更新时间:2023-11-03 22:32:04 25 4
gpt4 key购买 nike

我在 mongodb 中有一个集合,如下所述。

   { "UserID" : "User1",
"TaskId" : "Task1",
"SubTaskID" : "Subtask1",
"StartDate" : ISODate("2016-02-06T05:00:00Z"),
"EndDate" : ISODate("2016-02-06T05:00:00Z"),
"Hours" : 8, //no of hours worked between StartDate and EndDate on the subtask
"Department:"DEPT1"; //I can have multiple departments
"__v" : 0}

现在我想计算开始日期和结束日期之间的总工作小时数以及该期间内所有成员为部门中的该子任务输入的总小时数。我的输出应该是这样的

{
"TaskId":"TaskId1",
"UserId":"UserId1",
"startDate":"2016-02-06",
"endDate":"2016-02-06",
"totalHours": 10.0,
"deptTotalHours":100.0,
"subtasks": [
{
"SubTaskID": "SubTask1",
"totalHours": 4.0,
"deptTotalHours":40.0
},
{
"SubTaskID": "SubTask2",
"totalHours": 6.0,
"deptTotalHours":60.0
}]
}

我尝试过 $match、$project 和 $group,但无法获得指定格式的响应。有人可以建议我如何获得上述指定格式的响应吗?

最佳答案

使用以下管道操作将为您提供子任务所需的所有信息。那么所有子任务中的totalHours、deptTotalHours 只是子任务结果的记录总和(您可以在应用程序中执行此操作)。其余信息可作为您输入本身的一部分。


管道=[
{
$match: {}//根据开始和结束日期添加条件,此处不要包含 UserID 标准
},
{
$组:{
_id: '$SubTaskID',
deptTotalHours: {$sum: '$Hours'},
总小时数:{$sum:{$cond:[
{$eq: ['$UserID', inputUserId]},
'$小时',
0.0
]}
}
}
}
];

关于node.js - Node js、Mongoose计算总和并返回多个字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35355072/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com