ในการรวมฟิลด์ขนาดอาร์เรย์ ให้ใช้ $sum ร่วมกับ $size ให้เราสร้างคอลเลกชันที่มีเอกสาร -
> db.demo231.insertOne({"Subjects":["MongoDB","MySQL","SQL Server"]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e3fc73ff4cebbeaebec5143")
}
> db.demo231.insertOne({"Subjects":["Java","C","C++"]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e3fc757f4cebbeaebec5144")
}
> db.demo231.insertOne({"Subjects":["Python","Spring"]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e3fc762f4cebbeaebec5145")
} แสดงเอกสารทั้งหมดจากคอลเล็กชันโดยใช้วิธี find() -
> db.demo231.find();
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
{ "_id" : ObjectId("5e3fc73ff4cebbeaebec5143"), "Subjects" : [ "MongoDB", "MySQL", "SQL Server" ] }
{ "_id" : ObjectId("5e3fc757f4cebbeaebec5144"), "Subjects" : [ "Java", "C", "C++" ] }
{ "_id" : ObjectId("5e3fc762f4cebbeaebec5145"), "Subjects" : [ "Python", "Spring" ] } ต่อไปนี้เป็นแบบสอบถามเพื่อรวมฟิลด์ขนาดอาร์เรย์ใน MongoDB -
> db.demo231.aggregate([{'$group': {'_id': '_id', 'ToTalValue': {'$sum': {'$size': '$Subjects'}}}}]) สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
{ "_id" : "_id", "ToTalValue" : 8 }