MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Agrégation dans le fuseau horaire local dans mongodb

dans la version 3.6 de mongo, le fuseau horaire a été ajouté, mongo doc

expression pour extraire la partie date avec le fuseau horaire est

{ date: <dateExpression>, timezone: <tzExpression> }

nous pouvons soit spécifier le fuseau horaire ou le décalage lors de l'obtention des parties de date

pipeline

> db.txs.aggregate([
...     { $group:{
...         _id: { 
...             day: {$dayOfMonth: {date :"$date", timezone : "Europe/Rome"}}, // timezone
...             month: {$month: {date : "$date", timezone : "+02:00"}}, //offset
...             year: {$year: {date : "$date", timezone : "+02:00"}} //offset
...         },
...         count:{$sum:1}
...     }}
... ])

résultat

{ "_id" : { "day" : 10, "month" : 7, "year" : 2015 }, "count" : 1 }
{ "_id" : { "day" : 11, "month" : 7, "year" : 2015 }, "count" : 2 }
> 

liste des fuseaux horaires