考虑一个名为“方案”的集合,其中包含以下文档。如何查询预付费数组中包含“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"
}
],
}
}
您可以在此处使用$存在
运算符来检查数组中是否存在该属性
db.collection.find({
"plan.dataArray.a": {
$exists: true
}
})
输出
[
{
"plan": {
"dataArray": [
{
"a": "x",
"b": "y",
"c": "z"
},
{
"b": "x",
"c": "z"
}
]
}
}
]