面试题答案
一键面试[
{
$group: {
_id: "$department",
totalHoursPerProject: {
$push: {
$reduce: {
input: "$employees.projects",
initialValue: 0,
in: {
$cond: [
{ $eq: ["$$this.projectName", "$$value.projectName"] },
{
projectName: "$$this.projectName",
totalHours: { $add: ["$$this.hoursWorked", "$$value.totalHours"] }
},
{
projectName: "$$this.projectName",
totalHours: "$$this.hoursWorked"
}
]
}
}
}
},
averageProjectsPerEmployee: {
$avg: {
$size: "$employees.projects"
}
}
}
}
]