MongoDB find() 運算用於遞迴搜尋嗎?


結合點表示法使用 find() 執行遞迴搜尋。我們首先使用文件建立一個集合 -

> db.findOperationDemo.insertOne({"ClientDetails":[{"ClientId":101,"ClientName":"Chris"},{"ClientId":102,"ClientName":"Robert"}]});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd9a118b50a6c6dd317ad99")
}
> db.findOperationDemo.insertOne({"ClientDetails":[{"ClientId":110,"ClientName":"David"},{"ClientId":112,"ClientName":"Mike"}]});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd9a12fb50a6c6dd317ad9a")
}

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

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

這將產生以下輸出 -

{
   "_id" : ObjectId("5cd9a118b50a6c6dd317ad99"),
   "ClientDetails" : [
      {
         "ClientId" : 101,
         "ClientName" : "Chris"
      },
      {
         "ClientId" : 102,
         "ClientName" : "Robert"
      }
   ]
}
{
   "_id" : ObjectId("5cd9a12fb50a6c6dd317ad9a"),
   "ClientDetails" : [
      {
         "ClientId" : 110,
         "ClientName" : "David"
      },
      {
         "ClientId" : 112,
         "ClientName" : "Mike"
      }
   ]
}

以下是使用點表示法實現 find() 進行遞迴搜尋的查詢 -

> db.findOperationDemo.find({"ClientDetails.ClientId":110});

這將產生以下輸出 -

{ "_id" : ObjectId("5cd9a12fb50a6c6dd317ad9a"), "ClientDetails" : [ { "ClientId" : 110, "ClientName" : "David" }, { "ClientId" : 112, "ClientName" : "Mike" } ] }

更新於:2019 年 7 月 30 日

722 次瀏覽

開啟你的職業生涯

完成課程即可獲得認證

開始
廣告