【发布时间】:2019-03-28 12:29:01
【问题描述】:
考虑一下这条管道。
let Pipeline = [
{ $match: {
}},
{ $group: {
workHours: { $sum: { $divide: [ { $subtract: ['$workTime.end', '$workTime.start'] } , { $multiply: [3600, 1000] }] }},
breakHours: { $sum: { $divide: [ { $subtract: ['$breakTime.end', '$breakTime.start'] } , { $multiply: [3600, 1000] }] }},
weekEndHours: {
$cond: [
{ $or : [ { $eq : [{ $dayOfWeek : '$workTime.start' }, 1 ] }, {$eq : [{ $dayOfWeek : '$workTime.start' }, 7 ] }] },
{ $sum: { $divide: [ { $subtract: ['$workTime.end', '$workTime.start'] } , { $multiply: [3600, 1000] }] }},
0
]
}
}},
];
我正在尝试获取工作时间、休息时间和周末时间的总和。工作时间和休息时间都很好。现在我想在周末时间内使用条件,如果日期是 1 或 7,则计算密钥中的总小时数。
然后它向我显示错误“$cond 累加器是一元运算符”。我不知道我的群组查询出了什么问题。
【问题讨论】:
-
将 cond 移到 sum 内
-
@Veeram 你能修改答案中的代码吗?
-
如果你想通了,你应该粘贴解决方案作为你的问题的答案
标签: mongodb mongoose aggregation-framework