Я создаю API для регистрации сотрудников и отъезда для системы посещаемости.Для каждого сотрудника мне нужно подсчитать общее количество отработанных часов за месяц, а затем за год.Я пытался использовать агрегацию, проект и группу, но я не получаю общее количество рабочих часов в месяц или год.
Моя часть схемы выглядит следующим образом:
const EmployeeSchema = new Schema({
_id: Schema.Types.ObjectId,
attendance: [{
date: {type: Date, default: Date.now},
entry: {type: Date, required: false},
exit: {
time: {type: Date, required: false}
},
totalHours: {type: Number, required: false}
}]
)}
Для агрегирования я попытался реализовать этот способ:
exports.aggregation = (req, res) => {
const id = req.params.salespersonId;
DailySalesPerson.aggregate([
{$unwind: "$attendance"},
{
$group: {
_id: {
month: {"$month":"$attendance.date"}
},
totalHours: {$sum: "totalHours"},
count: {$sum: 1}
}
},
])
.then(result => {
res.status(200).json({result});
})
};
Я не получил общее количество часов, подсчитанное сотрудником за месяц или год.
Теперь мой результат выглядит следующим образом:
{
"result": [
{
"_id": "5c5bb13c1d92482b148ed17b",
"attendance": [
{
"date": "2019-02-07T04:30:07.391Z",
"totalHours": 1,
"month": 2,
"year": 2019
},
{
"date": "2019-02-07T04:51:05.359Z",
"totalHours": 1,
"month": 2,
"year": 2019
},
{
"date": "2019-02-07T04:56:21.951Z",
"totalHours": 1,
"month": 2,
"year": 2019
}
]
},
{
"_id": "5c5fdb1781165a1e58115da7",
"attendance": []
},
{
"_id": "5c5fdd1738ec411b1849ce58",
"attendance": [
{
"date": "2019-02-10T08:14:01.201Z",
"totalHours": 1,
"month": 2,
"year": 2019
}
]
},
{
"_id": "5c5fdf6336e9ea24e0e69795",
"attendance": [
{
"date": "2019-02-10T08:23:14.180Z",
"totalHours": 1,
"month": 2,
"year": 2019
}
]
}
]
}
Мне нужно объединить общее количество отработанных часов каждого человека за месяц и за год.Теперь мои результаты выглядят как выше.Как подсчитать общее количество часов каждого дня?