Jika Anda melakukan dan agregasi, Anda perlu melakukan yang serupa dengan SQL , yang berarti menentukan operasi agregasi per kolom, satu-satunya opsi yang Anda miliki adalah menggunakan $$ROOT
operator
db.test.aggregate(
[
{ $sort: { timestamp: 1 } },
{
$group:
{
_id: "$fooId",
timestamp: { $last: "$$ROOT" }
}
}
]
);
Tapi itu akan sedikit mengubah output
{ "_id" : "1", "timestamp" : { "_id" : ObjectId("570e6be3e81c8b195818e7fa"),
"fooId" : "1", "status" : "A", "timestamp" :ISODate("2016-01-01T00:00:00Z"),
"otherInfo" : "BAR" } }
Jika Anda ingin mengembalikan format dokumen asli, Anda mungkin memerlukan tahap $project setelah itu