Đối với điều này, bạn có thể sử dụng tổng hợp (). Chúng tôi đã coi các bản ghi thử nghiệm là “Value1”, “Value2”, v.v. Hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -
> db.demo432.insertOne( ... { ... "_id" : 101, ... "Name" : "David", ... "Value1" : 67, ... "Value2" : 87, ... "Value3" : 78 ... } ... ) { "acknowledged" : true, "insertedId" : 101 } > db.demo432.insertOne( ... { ... "_id" : 102, ... "Name" : "Sam", ... "Value1" : 98, ... "Value2" : 45, ... "Value3" : 90 ... } ... ) { "acknowledged" : true, "insertedId" : 102 }
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.demo432.find();
Điều này sẽ tạo ra kết quả sau -
{ "_id" : 101, "Name" : "David", "Value1" : 67, "Value2" : 87, "Value3" : 78 } { "_id" : 102, "Name" : "Sam", "Value1" : 98, "Value2" : 45, "Value3" : 90 }
Sau đây là truy vấn để lấy tên của những học sinh có một bài kiểm tra điểm dưới trung bình của tất cả các bài kiểm tra -
> db.demo432.aggregate([{ ... $project: { ... Name: '$Name', ... Value1: '$Value1', ... average: { ... $avg: ['$Value1', '$Value2', '$Value3'] ... } ... } ... }, ... { ... $group: { ... _id: null, ... NameValue1: { ... $push: { ... "Name": "$Name", ... "Value1": "$Value1" ... } ... }, ... totalAverage: { ... $avg: '$average' ... } ... } ... }, ... { $project: ... { lessthanAverageNames: ... { ... $map: ... { ... input: { ... $filter: { ... input: "$NameValue1", ... as: "out", ... cond: { ... $lt: ["$$out.Value1", "$totalAverage"] ... } ... } ... }, ... as: "o", ... in: "$$o.Name" ... } ... } ... } ... } ... ]);
Điều này sẽ tạo ra kết quả sau -
{ "_id" : null, "lessthanAverageNames" : [ "David" ] }