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

Truy vấn MongoDB cho các tài liệu khớp với mảng, không phân biệt thứ tự các phần tử

Đối với điều này, hãy sử dụng $ all trong MongoDB. Toán tử $ all trong MongoDB chọn các tài liệu trong đó giá trị của một trường là một mảng chứa tất cả các phần tử được chỉ định.

Trước tiên, hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -

> db.demo370.insertOne(
...    {
...       "Name" : "Chris",
...       "details" : [
...          {
...             "Subject" : "MySQL",
...             "CountryName" : "US"
...          },
...          {
...             "Subject" : "MongoDB",
...             "CountryName" : "UK"
...          }
...       ]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e57e9892ae06a1609a00af0")
}
> db.demo370.insertOne(
...    {
...       "Name" : "David",
...       "details" : [
...          {
               "Subject" : "Java",
...             "CountryName" : "AUS"
...          },
...          {
...             "Subject" : "Spring",
...             "CountryName" : "UK"
...          }
...       ]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e57e9972ae06a1609a00af1")
}

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

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

{
   "_id" : ObjectId("5e57e9892ae06a1609a00af0"), "Name" : "Chris", "details" : [
      { "Subject" : "MySQL", "CountryName" : "US" },
      { "Subject" : "MongoDB", "CountryName" : "UK" }
   ]
}
{
   "_id" : ObjectId("5e57e9972ae06a1609a00af1"), "Name" : "David", "details" : [
      { "Subject" : "Java", "CountryName" : "AUS" },
      { "Subject" : "Spring", "CountryName" : "UK" }
   ]
}

Sau đây là truy vấn cho các tài liệu khớp với mảng, không phân biệt thứ tự các phần tử -

> db.demo370.find({
...    details: {$all: [
...    {Subject:"MySQL","CountryName" : "US"},
...    {Subject:"MongoDB", "CountryName" : "UK"}
... ]}})

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

{
   "_id" : ObjectId("5e57e9892ae06a1609a00af0"), "Name" : "Chris", "details" : [
      { "Subject" : "MySQL", "CountryName" : "US" },
      { "Subject" : "MongoDB", "CountryName" : "UK" }
   ] 
}