Database

[{"gameDetails":[{"gameName":"hockey","playDate":"2014-05-05T00:00:00.000Z"},{"gameName":"football","playDate":"2022-06-05T00:00:00.000Z"}]},{"gameDetails":[{"gameName":"hockey","playDate":"2020-05-05T00:00:00.000Z"},{"gameName":"cricket","playDate":"2013-06-05T00:00:00.000Z"}]},{"gameDetails":[{"gameName":"cricket","playDate":"2013-05-05T00:00:00.000Z"},{"gameName":"football","playDate":"2021-06-05T00:00:00.000Z"}]},{"gameDetails":[{"gameName":"cricket","playDate":"2009-05-05T00:00:00.000Z"},{"gameName":"hockey","playDate":"2021-06-05T00:00:00.000Z"}]}]

Query

db.collection.aggregate([{$match:{gameDetails:{$elemMatch:{"gameName":"hockey"}}}},{$set:{hockeyData:{$first:{$filter:{input:"$gameDetails",cond:{$eq:["$$this.gameName","hockey"]}}}}}},{$sort:{"hockeyData.playDate":-1}},{$unset:"hockeyData"}])

Result