Retrieve only the queried element in an object array in MongoDB collection

Suppose you have the following documents in my collection: { “_id”:ObjectId(“562e7c594c12942f08fe4192”), “shapes”:[ { “shape”:”square”, “color”:”blue” }, { “shape”:”circle”, “color”:”red” } ] }, { “_id”:ObjectId(“562e7c594c12942f08fe4193”), “shapes”:[ { “shape”:”square”, “color”:”black” }, { “shape”:”circle”, “color”:”green” } ] } Do query: db.test.find({“shapes.color”: “red”}, {“shapes.color”: 1}) Or db.test.find({shapes: {“$elemMatch”: {color: “red”}}}, {“shapes.color”: 1}) Returns matched document (Document 1), but always … Read more