Đối với điều này, hãy sử dụng $ project và trong đó, $ size để lấy chiều dài. 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.demo382.insertOne( ... { ... ... "Name" : "David", ... "details" : [ ... { ... "SubjectName":"MySQL" ... }, ... { ... "SubjectName":"MongoDB" ... }, ... { ... "SubjectName":"Java" ... } ... ] ... ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5e5b5e1c22064be7ab44e7f0") }
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 () &Minus;
> db.demo382.find().pretty();
Điều này sẽ tạo ra kết quả sau -
{ "_id" : ObjectId("5e5b5e1c22064be7ab44e7f0"), "Name" : "David", "details" : [ { "SubjectName" : "MySQL" }, { "SubjectName" : "MongoDB" }, { "SubjectName" : "Java" } ] }
Sau đây là truy vấn để tổng hợp $ Slice và lấy độ dài -
> db.demo382.aggregate([ ... { "$match": { "Name": "David" } }, ... { "$project": { "count": { "$size": "$details" }}} ... ])
Điều này sẽ tạo ra kết quả sau -
{ "_id" : ObjectId("5e5b5e1c22064be7ab44e7f0"), "count" : 3 }