MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

mongodb:Zusammenfassung der Aufzeichnungen finden

Die Datumsoperatoren müssen in einem $project verwendet werden Vorgang, keine $group , also müssen Sie es stattdessen so machen (in der Shell):

db.tickers.aggregate(
    { $project: {
        _id: 0,
        year: {$year: '$date'},
        month: {$month: '$date'},
        day: {$dayOfMonth: '$date'},
        hour: {$hour: '$date'},
        avg: '$ticker.avg'
    }},
    { $group: {
        _id: { year: '$year', month: '$month', day: '$day', hour: '$hour' },
        avg: { $avg: '$avg'}
    }});

Liefert ein Ergebnis von:

{
  "result": [
    {
      "_id": {
        "year": 2012,
        "month": 12,
        "day": 19,
        "hour": 10
      },
      "avg": 13.244705635
    }
  ],
  "ok": 1
}