Jeśli robisz agregację, musisz zrobić coś podobnego do SQL , co oznacza określenie operacji agregacji na kolumnę, jedyną dostępną opcją jest użycie $$ROOT
operator
db.test.aggregate(
[
{ $sort: { timestamp: 1 } },
{
$group:
{
_id: "$fooId",
timestamp: { $last: "$$ROOT" }
}
}
]
);
Ale to trochę zmieni wyjście
{ "_id" : "1", "timestamp" : { "_id" : ObjectId("570e6be3e81c8b195818e7fa"),
"fooId" : "1", "status" : "A", "timestamp" :ISODate("2016-01-01T00:00:00Z"),
"otherInfo" : "BAR" } }
Jeśli chcesz zwrócić oryginalny format dokumentu, prawdopodobnie będziesz potrzebować później etapu $project