Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> MongoDB

แบบสอบถาม MongoDB เพื่อรับบันทึกที่เริ่มต้นด้วยองค์ประกอบเฉพาะจากอาร์เรย์?


คุณสามารถใช้เครื่องหมายจุด (.) ร่วมกับดัชนีอาร์เรย์เพื่อเริ่มต้นบันทึกด้วยองค์ประกอบเฉพาะ ให้เราสร้างคอลเลกชันที่มีเอกสารก่อน -

>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")
}

ต่อไปนี้เป็นแบบสอบถามเพื่อแสดงเอกสารทั้งหมดจากคอลเลกชันโดยใช้วิธี find() -

> db.arrayStartsWithElementDemo.find().pretty();

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -

{
   "_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
   ]
}

ต่อไปนี้เป็นแบบสอบถามเพื่อรับอาร์เรย์ที่เริ่มต้นด้วยองค์ประกอบเฉพาะ 890 และ 670 -

> db.arrayStartsWithElementDemo.find({"PlayerScore.0" : 890, "PlayerScore.1" : 670}).pretty();

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ ที่นี่

{
   "_id" : ObjectId("5cd2a00c345990cee87fd88a"),
   "PlayerName" : "Robert",
   "PlayerScore" : [
      890,
      670,
      890,
      54646,
      42424
   ]
}