Computer >> Máy Tính >  >> Lập trình >> MongoDB

Tổng hợp theo quốc gia, tiểu bang và thành phố trong bộ sưu tập MongoDB với nhiều tài liệu

Thao tác tổng hợp nhóm các giá trị từ nhiều tài liệu lại với nhau và có thể thực hiện nhiều thao tác khác nhau trên dữ liệu được nhóm để trả về một kết quả duy nhất.

Để tổng hợp trong MongoDB, hãy sử dụng tổng hợp (). Hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -

> db.demo620.insertOne({"Country":"IND","City":"Delhi",state:"Delhi"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e9a8de96c954c74be91e6a1")
}
> db.demo620.insertOne({"Country":"IND","City":"Bangalore",state:"Karnataka"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e9a8e336c954c74be91e6a3")
}
> db.demo620.insertOne({"Country":"IND","City":"Mumbai",state:"Maharashtra"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e9a8e636c954c74be91e6a4")
}

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.demo620.find();

Điều này sẽ tạo ra kết quả sau -

{ "_id" : ObjectId("5e9a8de96c954c74be91e6a1"), "Country" : "IND", "City" : "Delhi", "state" : "Delhi" }
{ "_id" : ObjectId("5e9a8e336c954c74be91e6a3"), "Country" : "IND", "City" : "Bangalore", "state" : "Karnataka" }
{ "_id" : ObjectId("5e9a8e636c954c74be91e6a4"), "Country" : "IND", "City" : "Mumbai", "state" : "Maharashtra" }

Sau đây là truy vấn để tổng hợp theo quốc gia, tiểu bang và thành phố -

> db.demo620.aggregate([
...    { "$group": {
...       "_id": {
...          "Country": "$Country",
...          "state": "$state"
...       },
...       "City": {
...          "$addToSet": {
...             "City": "$City"
...          }
...       }
...    }},
...    { "$group": {
...       "_id": "$_id.Country",
...       "states": {
...          "$addToSet": {
...             "state": "$_id.state",
...             "City": "$City"
...          }
...       }
...    }}
... ]).pretty();

Điều này sẽ tạo ra kết quả sau -

{
   "_id" : "IND",
   "states" : [
      {
         "state" : "Delhi",
         "City" : [
            {
               "City" : "Delhi"
            }
         ]
      },
      {
         "state" : "Maharashtra",
         "City" : [
            {
                  "City" : "Mumbai"
            }
         ]
      },
      {
         "state" : "Karnataka",
         "City" : [
            {
               "City" : "Bangalore"
            }
         ]
      }
   ]
}