我有一个包含嵌套数组数据的文档。我曾无助地尝试使用$elemMatch
过滤数据,但我无法弄清楚为什么它不起作用。
{
'id' : 1,
'name' : 'test',
'modules' : [
{
name: 'foo',
mandatory: false,
group: [
{
name: g1
}]
},
{
name: 'bar',
mandatory: false,
group: [
{
name: g2
}]
}]
}
我尝试使用以下查询:
db.test.find(
{
modules: {
$elemMatch: {
name: "foo",
}
}
}
但是它一直返回所有的模块。如果我使用
mandatory: true
,则不会返回任何内容,这似乎表明它起作用了。你有什么想法我做错了什么吗?谢谢!