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

Làm cách nào để lấy dữ liệu của giao điểm mảng trong MongoDB?

Đối với tương tác mảng trong MongoDB, hãy sử dụng $ setIntersection trong 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.demo625.insertOne(
...    {
...       Name: "John",
...       Marks: [56,98,60]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e9ab8e16c954c74be91e6aa")
}
> db.demo625.insertOne(
...    {
...       Name: "John",
...       Marks: [110,56,72]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e9ab8e26c954c74be91e6ab")
}
> db.demo625.insertOne(
...    {
...       Name: "Chris",
...       Marks: [90,91]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e9ab8e26c954c74be91e6ac")
}
> db.demo625.insertOne(
...    {
...       Name: "Robert",
...       Marks: [60,75]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e9ab8e26c954c74be91e6ad")
}

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

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

{ "_id" : ObjectId("5e9ab8e16c954c74be91e6aa"), "Name" : "John", "Marks" : [ 56, 98, 60 ] }
{ "_id" : ObjectId("5e9ab8e26c954c74be91e6ab"), "Name" : "John", "Marks" : [ 110, 56, 72 ] }
{ "_id" : ObjectId("5e9ab8e26c954c74be91e6ac"), "Name" : "Chris", "Marks" : [ 90, 91 ] }
{ "_id" : ObjectId("5e9ab8e26c954c74be91e6ad"), "Name" : "Robert", "Marks" : [ 60, 75 ] }

Sau đây là truy vấn để lấy dữ liệu của giao điểm mảng trong MongoDB -

> db.demo625.aggregate([
...
...
...    { "$project": {
...       "Name": 1,
...       "Marks": {
...          "$setIntersection": [ "$Marks", [56,98,60] ]
...       }
...    }}
... ])

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

{ "_id" : ObjectId("5e9ab8e16c954c74be91e6aa"), "Name" : "John", "Marks" : [ 56, 60, 98 ] }
{ "_id" : ObjectId("5e9ab8e26c954c74be91e6ab"), "Name" : "John", "Marks" : [ 56 ] }
{ "_id" : ObjectId("5e9ab8e26c954c74be91e6ac"), "Name" : "Chris", "Marks" : [ ] }
{ "_id" : ObjectId("5e9ab8e26c954c74be91e6ad"), "Name" : "Robert", "Marks" : [ 60 ] }