提问者:小点点

检查数组中是否存在字段[重复]


考虑一个名为“方案”的集合,其中包含以下文档。如何查询预付费数组中包含“a”的至少元素的所有方案?这里第一个集合满足条件,因为dataArray[0]有“a”。第二个集合没有。因此,我想查询以仅查找此类集合整个dataArray在其一个元素中包含“a”。

{
    "plan":{
        "dataArray" : [
                 {
                     "a" : "x",
                     "b" : "y",
                     "c" : "z"
                 },
                 {
                     "b" : "x",
                     "c" : "z"
                 }
            ],
        }
}
{
    "plan":{
        "dataArray" : [
            {
                "b" : "y",
                "c" : "z"
            },
            {
                "b" : "x",
                "c" : "z"
            }
        ],
    }
}

共1个答案

匿名用户

您可以在此处使用$存在运算符来检查数组中是否存在该属性

db.collection.find({
  "plan.dataArray.a": {
    $exists: true
  }
})

输出

[
  {
    "plan": {
      "dataArray": [
        {
          "a": "x",
          "b": "y",
          "c": "z"
        },
        {
          "b": "x",
          "c": "z"
        }
      ]
    }
  }
]