考虑一个名为“scheme”的集合,其中包含以下文档。如何查询包年包月数组中至少包含a元素的所有方案?这里第一个集合满足条件,因为dataArray有'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"
}
],
}
}
发布于 2018-06-06 03:47:05
您可以在此处使用运算符检查该属性是否存在于数组中
db.collection.find({
"plan.dataArray.a": {
$exists: true
}
})
输出
[
{
"plan": {
"dataArray": [
{
"a": "x",
"b": "y",
"c": "z"
},
{
"b": "x",
"c": "z"
}
]
}
}
]
https://stackoverflow.com/questions/50707383
复制相似问题