mongodb如何查询sub collection中的某个document?

有如下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

绝地无双
浏览 1435回答 1
1回答

慕丝7291255

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 }
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

MongoDB