Vous pouvez essayer l'agrégation ci-dessous dans mongodb 4.0
Vous pouvez convertir timestamp
à ce jour en utilisant $toDate
agrégation puis $group
avec $month
agrégation
db.collection.aggregate([
{ "$match": { "type": "deposits" }},
{ "$addFields": {
"date": {
"$toDate": "$timestamp"
}
}},
{ "$group": {
"_id": { "$month": "$date" },
"deposits": {
"$push": "$$ROOT"
}
}}
])
Vous pouvez essayer l'agrégation ci-dessous dans mongodb 3.4
En 3.4 vous pouvez convertir timestamp
à ce jour en ajoutant new Date()
dedans et $group
en utilisant $dateToString
agrégation
db.collection.aggregate([
{ "$match": { "type": "deposits" }},
{ "$addFields": {
"date": {
"$add": [ new Date(0), "$timestamp" ]
}
}},
{ "$group": {
"_id": {
"$dateToString": {
"format": "%m",
"date": "$date"
}
},
"deposits": {
"$push": "$$ROOT"
}
}}
])