有如下collection: 中有如下collection:[{name: 'micheal jackson',albums: [{ name: 'Got To Be There', year: 1972 },{ name: 'Ben', year: 1972 },{ name: 'Forever,Michael', year: 1975 }]}]怎样查询出{ name: 'Ben', year: 1972 } 这个document,请注意:只要sub document
1 回答
慕丝7291255
TA贡献1859条经验 获得超6个赞
11) $elemMatch
如果对象有一个元素是数组,那么$elemMatch可以匹配内数组内的元素:
> t.find( { x : { $elemMatch : { a : 1, b : { $gt : 1 } } } } ) { "_id" : ObjectId("4b5783300334000000000aa9"), "x" : [ { "a" : 1, "b" : 3 }, 7, { "b" : 99 }, { "a" : 11 } ]}$elemMatch : { a : 1, b : { $gt : 1 } } 所有的条件都要匹配上才行。注意,上面的语句和下面是不一样的。
> t.find( { "x.a" : 1, "x.b" : { $gt : 1 } } )
$elemMatch是匹配{ "a" : 1, "b" : 3 },而后面一句是匹配{ "b" : 99 }, { "a" : 11 }
- 1 回答
- 0 关注
- 1455 浏览
添加回答
举报
0/150
提交
取消