You can use dot(.) notation along with array index to get record beginning with specific element. Let us first create a collection with documents −
>db.arrayStartsWithElementDemo.insertOne({"PlayerName":"Chris","PlayerScore":[780,9000,456,789,987]}); { "acknowledged" : true, "insertedId" : ObjectId("5cd29fed345990cee87fd889") } >db.arrayStartsWithElementDemo.insertOne({"PlayerName":"Robert","PlayerScore":[890,670,890,54646,42424]}); { "acknowledged" : true, "insertedId" : ObjectId("5cd2a00c345990cee87fd88a") } >db.arrayStartsWithElementDemo.insertOne({"PlayerName":"David","PlayerScore":[909090,896555,3344433,78900]}); { "acknowledged" : true, "insertedId" : ObjectId("5cd2a025345990cee87fd88b") }
Following is the query to display all documents from a collection with the help of find() method −
> db.arrayStartsWithElementDemo.find().pretty();
This will produce the following output −
{ "_id" : ObjectId("5cd29fed345990cee87fd889"), "PlayerName" : "Chris", "PlayerScore" : [ 780, 9000, 456, 789, 987 ] } { "_id" : ObjectId("5cd2a00c345990cee87fd88a"), "PlayerName" : "Robert", "PlayerScore" : [ 890, 670, 890, 54646, 42424 ] } { "_id" : ObjectId("5cd2a025345990cee87fd88b"), "PlayerName" : "David", "PlayerScore" : [ 909090, 896555, 3344433, 78900 ] }
Following is the query to get array beginning with specific elements 890 and then 670 −
> db.arrayStartsWithElementDemo.find({"PlayerScore.0" : 890, "PlayerScore.1" : 670}).pretty();
This will produce the following output. Here,
{ "_id" : ObjectId("5cd2a00c345990cee87fd88a"), "PlayerName" : "Robert", "PlayerScore" : [ 890, 670, 890, 54646, 42424 ] }