Database
[{"_id":{"$oid":"636957ce994af955df472ebc"},"route":[{"stationCode":"DHN","distanceFromOrigin":0,"_id":{"$oid":"636957ce994af955df472ebd"}},{"stationCode":"KMME","distanceFromOrigin":38,"_id":{"$oid":"636957ce994af955df472ebe"}},{"stationCode":"ASN","distanceFromOrigin":54,"_id":{"$oid":"636957ce994af955df472ebf"}}],"__v":0},{"_id":{"$oid":"636957ce994af955df472ebd"},"route":[{"stationCode":"ASN","distanceFromOrigin":0,"_id":{"$oid":"636957ce994af955df472ebd"}},{"stationCode":"KMME","distanceFromOrigin":38,"_id":{"$oid":"636957ce994af955df472ebe"}},{"stationCode":"DHN","distanceFromOrigin":54,"_id":{"$oid":"636957ce994af955df472ebf"}}],"__v":0},{"_id":{"$oid":"636957ce994af955df472ebe"},"route":[{"stationCode":"ATP","distanceFromOrigin":0,"_id":{"$oid":"636957ce994af955df472ebd"}},{"stationCode":"DHN","distanceFromOrigin":54,"_id":{"$oid":"636957ce994af955df472ebf"}}],"__v":0}]
Query
db.collection.aggregate([{$match:{$expr:{"$setIsSubset":[["ASN","KMME"],"$route.stationCode"]}}},{$set:{wanted:{$first:{$filter:{input:"$route",cond:{$in:["$$this.stationCode",["ASN","KMME"]]}}}}}},{$match:{"wanted.stationCode":"KMME",}},{$unset:"wanted"}])