Database
[{"userref":"AAA","sessionref":"S1","results":[{"gameref":"Spades","dateplayed":ISODate("2022-01-01T10:00:00Z"),"score":1000},{"gameref":"Hearts","dateplayed":ISODate("2022-01-02T10:00:00Z"),"score":500},{"gameref":"Clubs","dateplayed":ISODate("2022-01-05T10:00:00Z"),"score":200}]},{"userref":"AAA","sessionref":"S2","results":[{"gameref":"Spades","dateplayed":ISODate("2022-02-02T10:00:00Z"),"score":1000},{"gameref":"Clubs","dateplayed":ISODate("2022-05-02T10:00:00Z"),"score":200}]},{"userref":"BBB","sessionref":"S1","results":[{"gameref":"Clubs","dateplayed":ISODate("2022-01-05T10:00:00Z"),"score":200}]}]
Query
db.collection.aggregate([{"$set":{"results":{"$filter":{"input":"$results","cond":{"$eq":["$$this.gameref","Clubs"]}}}}},{"$unwind":"$results"},{"$sort":{"results.dateplayed":-1}},{"$group":{"_id":"$userref","results":{"$first":"$results"},"sessionref":{"$first":"$sessionref"}}}])