如何在 MongoDB 中匹配陣列中的多個條件?


要匹配陣列中的多個條件,請使用 aggregate()。讓我們建立一個包含文件的集合 -

> db.demo84.insertOne({
...    "EmployeeDetails": [
...       {Name: 'John', Salary:45000, isMarried: true},
...       {Name: 'Chris', Salary:50000, isMarried: false}
...       ]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e2c0a3471bf0181ecc422a5")
}
> db.demo84.insertOne({
...    "EmployeeDetails": [
...       {Name: 'Sam', Salary:56000, isMarried: false},
...       {Name: 'Bob', Salary:50000, isMarried: false}
...       ]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e2c0a4071bf0181ecc422a6")
}

使用 find() 方法從集合中顯示所有文件 -

> db.demo84.find();

這將產生以下輸出 -

{
   "_id" : ObjectId("5e2c0a3471bf0181ecc422a5"), "EmployeeDetails" : [
      { "Name" : "John", "Salary" : 45000, "isMarried" : true },
      { "Name" : "Chris", "Salary" : 50000, "isMarried" : false }
   ]
}
{
   "_id" : ObjectId("5e2c0a4071bf0181ecc422a6"), "EmployeeDetails" : [
      { "Name" : "Sam", "Salary" : 56000, "isMarried" : false },
      { "Name" : "Bob", "Salary" : 50000, "isMarried" : false }
   ]
}

以下是匹配陣列中的多個條件的查詢 -

示例

> db.demo84.aggregate(
...    { "$match": {
...       "EmployeeDetails": {
...          "$elemMatch": {
...             "Name": "Chris",
...          "isMarried": false
...          }
...       }
...    }}
... );

這將產生以下輸出 -

{
   "_id" : ObjectId("5e2c0a3471bf0181ecc422a5"), "EmployeeDetails" : [
      { "Name" : "John", "Salary" : 45000, "isMarried" : true },
      { "Name" : "Chris", "Salary" : 50000, "isMarried" : false }
   ] 
}

更新於: 2020 年 3 月 30 日

893 閱讀次數

開啟你的 職業

完成課程,獲得認證

入門
廣告
© . All rights reserved.