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

Regroupez les documents Mongo par identifiant et obtenez le dernier document par horodatage

Si vous faites une agrégation, vous devez faire comme SQL , ce qui signifie spécifier l'opération d'agrégation par colonne, la seule option que vous avez est d'utiliser le $$ROOT opérateur

db.test.aggregate(
   [
    { $sort: { timestamp: 1 } },
     {
       $group:
         {
           _id: "$fooId",
           timestamp: { $last: "$$ROOT" }
         }
     }
   ]
);

Mais cela changera un peu la sortie

{ "_id" : "1", "timestamp" : { "_id" : ObjectId("570e6be3e81c8b195818e7fa"), 
  "fooId" : "1", "status" : "A", "timestamp" :ISODate("2016-01-01T00:00:00Z"), 
  "otherInfo" : "BAR" } }

Si vous souhaitez revenir au format de document d'origine, vous aurez probablement besoin d'une étape $project après cela