如何在 MongoDB 中檢索巢狀物件?
要在 MongoDB 中檢索巢狀物件,請使用 $ 運算子。我們首先建立一個包含文件的集合 -
> db.queryNestedObject.insertOne( ... { ... "StudentName" : "James", ... "StudentSubjectScore" : [ ... {"StudentMongoDBScore":98}, ... {"StudentCScore":92}, ... {"StudentJavaScore":91} ... ] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5ccf49a9dceb9a92e6aa1962") }
以下是對集合中所有文件使用 find() 方法顯示的所有內容 -
> db.queryNestedObject.find().pretty();
這將產生以下輸出 -
{ "_id" : ObjectId("5ccf49a9dceb9a92e6aa1962"), "StudentName" : "James", "StudentSubjectScore" : [ { "StudentMongoDBScore" : 98 }, { "StudentCScore" : 92 }, { "StudentJavaScore" : 91 } ] }
以下是檢索巢狀物件的方法 -
> db.queryNestedObject.find({'StudentSubjectScore.StudentJavaScore' : 91},{'StudentSubjectScore.$': 1 , _id: 0});
這將產生以下輸出 -
{ "StudentSubjectScore" : [ { "StudentJavaScore" : 91 } ] }
廣告