Estoy trabajando en la agregación para realizar algunos análisis en un objeto Orders
, quiero obtener el precio total de cada pedido del mes anterior y el total de este mes, intenté pasar el parámetro $match
, con las condiciones de tiempo adecuadas pero no está agregando ninguno de los datos. aunque si realizo una consulta de countDocuments
de documentos con las mismas condiciones de tiempo, obtengo una cantidad de documentos devueltos.
const totalThis = await Order.aggregate([ { $match: { // should cut the amount of orders off at the beginning of the current month createdAt: { $gte: thisMonth.getMonth() + 1 }, }, }, { $group: { // using $group, _id has to be there or it doesnt // return anything, though we dont need an _id _id: null, total: { $sum: "$totalPrice", }, }, }, ]); res.status(200).json({ lastMonth: lastMonthSales, thisMonth: thisMonthSales, totalSalesLast: totalLast, totalSalesThis: totalThis, });
En mi solicitud de Postman, lastMonth
devuelve 0, por lo que tendría sentido que la matriz devuelta a totalSalesLast
estuviera vacía, sin embargo, thisMonth
devuelve 5 documentos, por lo que debería funcionar. Obviamente, si elimino el condicional $match
, agregará todos los documentos, pero eso es porque está haciendo TODOS los documentos y no filtrando.
Para consultar el documento con createdAt
en un mes específico, su etapa $match
debe ser la siguiente:
$month
: tome el valor del mes de createdAt
.$eq
: compara el mes de (1) y el mes de entrada son iguales. { $match: { $expr: { $eq: [ { "$month": "$createdAt" }, thisMonth.getMonth() + 1 ] } } }