Я столкнулся с проблемой с агрегацией в mongodb, так как я группирую результат и суммирую его, преобразовываю поданное в двойное число и помещаю в Error или On null, я возвращаю 0
, но на выходе получается NaN
.
let $match= {
$and:[{
status:{ $in:['Completed'] }
},{
type:0
}, {
"price": { "$exists": true, "$ne": null }
},{
"invoice_value": {
"$exists": true, "$ne": null
}
}]
};
if(Object.keys(query).length>0){
console.log(query);
$match.$and.push(query);
}
try {
const res = await Order.aggregate([
{ $match },
{
$group: {
_id: null,
Prices: {
$sum: {
$convert:
{
input: '$price',
to: 'double',
onError: 0,
onNull: 0
}
}
},
Invoices: {
$sum: {
$convert:
{
input: '$invoice_value',
to: 'double',
onError: 0,
onNull: 0
}
}
},
count: {
$sum: 1
}
}
}
])
}catch (e) {
console.error(e);
}
Выход:
[{
_id: null,
Prices: NaN,
Invoices: 834565.92,
count: 25211
}]