【问题标题】:MongoError: The $cond accumulator is a unary operatorMongoError:$cond 累加器是一元运算符
【发布时间】: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


【解决方案1】:

得到了解决方案,还扩展了管道条件。

let Pipeline = [
    { $match: {
    }},
    { $group: {
        _id: '$memberId',
        workHours: { $sum: { $divide: [ { $subtract: ['$workTime.end', '$workTime.start'] } , { $multiply: [3600, 1000] }] }},
        breakHours: { $sum: { $divide: [ { $subtract: ['$breakTime.end', '$breakTime.start'] } , { $multiply: [3600, 1000] }] }},
        weekEndHours: {
            $sum: {
                $cond: [
                    { $or : [ { $eq : [{ $dayOfWeek : { date: '$workTime.start', timezone: timezoneOffset}}, 1 ] }, {$eq : [{ $dayOfWeek : { date: '$workTime.start', timezone: timezoneOffset}}, 7 ] }] },
                    { $divide: [ { $subtract: ['$workTime.end', '$workTime.start'] } , { $multiply: [3600, 1000] }] },
                    0
                ]
            }
        },
        weekDayHours: {
            $sum: {
                $cond: [
                    { $or : [
                            { $eq : [{ $dayOfWeek : { date: '$workTime.start', timezone: timezoneOffset}}, 2 ] },
                            { $eq : [{ $dayOfWeek : { date: '$workTime.start', timezone: timezoneOffset}}, 3 ] },
                            { $eq : [{ $dayOfWeek : { date: '$workTime.start', timezone: timezoneOffset}}, 4 ] },
                            { $eq : [{ $dayOfWeek : { date: '$workTime.start', timezone: timezoneOffset}}, 5 ] },
                            { $eq : [{ $dayOfWeek : { date: '$workTime.start', timezone: timezoneOffset}}, 6 ] }
                        ]
                    },
                    { $divide: [ { $subtract: ['$workTime.end', '$workTime.start'] } , { $multiply: [3600, 1000] }] },
                    0
                ]
            }
        },
    }},
    { $addFields:{
        totalWorkedHours: { $subtract: [ '$workHours', '$breakHours'] }
    }}
];

【讨论】:

    猜你喜欢
    • 2018-10-09
    • 2021-07-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-03-11
    • 2015-10-15
    • 2020-10-03
    相关资源
    最近更新 更多