Để truy xuất một đối tượng lồng nhau trong MongoDB, hãy sử dụng toán tử $. Trước tiên, hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -
> db.queryNestedObject.insertOne( ... { ... "StudentName" : "James", ... "StudentSubjectScore" : [ ... {"StudentMongoDBScore":98}, ... {"StudentCScore":92}, ... {"StudentJavaScore":91} ... ] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5ccf49a9dceb9a92e6aa1962") }
Sau đây là truy vấn để hiển thị tất cả các tài liệu từ một bộ sưu tập với sự trợ giúp của phương thức find () -
> db.queryNestedObject.find().pretty();
Điều này sẽ tạo ra kết quả sau -
{ "_id" : ObjectId("5ccf49a9dceb9a92e6aa1962"), "StudentName" : "James", "StudentSubjectScore" : [ { "StudentMongoDBScore" : 98 }, { "StudentCScore" : 92 }, { "StudentJavaScore" : 91 } ] }
Sau đây là truy vấn để lấy một đối tượng lồng nhau -
> db.queryNestedObject.find({'StudentSubjectScore.StudentJavaScore' : 91},{'StudentSubjectScore.$': 1 , _id: 0});
Điều này sẽ tạo ra kết quả sau -
{ "StudentSubjectScore" : [ { "StudentJavaScore" : 91 } ] }