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

Zip hai mảng và tạo mảng đối tượng mới ở dạng được định hình lại với MongoDB

Đối với điều này, hãy sử dụng tổng hợp cùng với $ zip. Mã zip được sử dụng để chuyển một mảng. Hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -

> db.demo339.insertOne({Id:101,Score1:["98","56"],Score2:[67,89]});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e529ee5f8647eb59e5620a2")
}

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

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

{ "_id" : ObjectId("5e529ee5f8647eb59e5620a2"), "Id" : 101, "Score1" : [ "98", "56" ], "Score2" : [ 67, 89 ] }

Sau đây là truy vấn để nén hai mảng với $ zip và tạo một mảng đối tượng mới -

> db.demo339.aggregate([
...    {
...       "$project": {
...          "AllArrayObject": {
...             "$map": {
...                "input": {
...                   "$objectToArray": {
...                      "$arrayToObject": {
...                         "$zip": {
...                            "inputs": [
...                               "$Score1",
...                               "$Score2"
...                            ]
...                         }
...                      }
...                   }
...                },
.
...                "as": "el",
...                "in": {
...                   "Score1": "$$el.k",
...                   "Score2": "$$el.v"
...                }
...             }
...          }
...       }
...    }
... ])

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

{ "_id" : ObjectId("5e529ee5f8647eb59e5620a2"), "AllArrayObject" : [ { "Score1" : "98", "Score2" : 67 }, { "Score1" : "56", "Score2" : 89 } ] }