MongoError: аккумулятор $ cond является унарным оператором - PullRequest
0 голосов
/ 24 октября 2018

Рассмотрим этот конвейер.

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унарный оператор ».Я не знаю, что не так с моим групповым запросом.

1 Ответ

0 голосов
/ 20 декабря 2018

Есть решение, а также расширенные условия трубопровода.

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'] }
    }}
];
...