用 MongoDB 的查詢中檢索陣列值?


要檢索陣列值,請使用點(.)表示法。我們首先使用文件建立一個集合 −

> db.retrievingArrayDemo.insertOne(
   { "UserDetails" : [
      { "UserName" : "John", "UserAge" : 23 } ],
      "UserCountryName" : "AUS",
      "UserLoginDate" : new ISODate(),
      "UserMessage" : "Hello"
   }
);
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ce9718478f00858fb12e920")
}
> db.retrievingArrayDemo.insertOne(
   { "UserDetails" : [
      { "UserName" : "Sam", "UserAge" : 24 } ],
      "UserCountryName" : "UK",
      "UserLoginDate" : new ISODate(),
      "UserMessage" : "Bye"
   }
);
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ce9718478f00858fb12e921")
}

以下是使用 find() 方法從集合顯示所有文件的查詢 −

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

這將生成以下輸出 −

{
   "_id" : ObjectId("5ce9718478f00858fb12e920"),
   "UserDetails" : [
      {
         "UserName" : "John",
         "UserAge" : 23
      }
   ],
   "UserCountryName" : "AUS",
   "UserLoginDate" : ISODate("2019-05-25T16:47:00.211Z"),
   "UserMessage" : "Hello"
}
{
   "_id" : ObjectId("5ce9718478f00858fb12e921"),
   "UserDetails" : [
      {
         "UserName" : "Sam",
         "UserAge" : 24
      }
   ],
   "UserCountryName" : "UK",
   "UserLoginDate" : ISODate("2019-05-25T16:47:00.670Z"),
   "UserMessage" : "Bye"
}

以下是從 find 查詢中檢索陣列值的查詢 −

> db.retrievingArrayDemo.find({"UserCountryName" : "UK", "UserDetails.UserName":"Sam"}).pretty();

這將生成以下輸出 −

{
   "_id" : ObjectId("5ce9718478f00858fb12e921"),
   "UserDetails" : [
      {
         "UserName" : "Sam",
         "UserAge" : 24
      }
   ],
   "UserCountryName" : "UK",
   "UserLoginDate" : ISODate("2019-05-25T16:47:00.670Z"),
   "UserMessage" : "Bye"
}

更新日期: 2019-07-30

97 次瀏覽

開啟你 職業生涯

完成該課程獲取認證

開始學習
廣告
© . All rights reserved.