有如下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 關注
- 1472 瀏覽
添加回答
舉報
0/150
提交
取消