MongoDB 聚合 $slice 以獲取陣列的長度
為此,請使用 $project,其中使用 $size 獲取長度。我們首先建立一個文件集合 -
> db.demo382.insertOne( ... { ... ... "Name" : "David", ... "details" : [ ... { ... "SubjectName":"MySQL" ... }, ... { ... "SubjectName":"MongoDB" ... }, ... { ... "SubjectName":"Java" ... } ... ] ... ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5e5b5e1c22064be7ab44e7f0") }
使用 find() 方法顯示集合中的所有文件 -
> db.demo382.find().pretty();
這將生成以下輸出 -
{ "_id" : ObjectId("5e5b5e1c22064be7ab44e7f0"), "Name" : "David", "details" : [ { "SubjectName" : "MySQL" }, { "SubjectName" : "MongoDB" }, { "SubjectName" : "Java" } ] }
以下是用於聚合 $slice 和獲取長度的查詢 -
> db.demo382.aggregate([ ... { "$match": { "Name": "David" } }, ... { "$project": { "count": { "$size": "$details" }}} ... ])
這將生成以下輸出 -
{ "_id" : ObjectId("5e5b5e1c22064be7ab44e7f0"), "count" : 3 }
廣告