有如下collection: 中有如下collection:[{name: 'micheal jackson',albums: [{ name: 'Got To Be There', year: 1972 },{ name: 'Ben', year: 1972 },{ name: 'Forever,Michael', year: 1975 }]}]怎樣查詢(xún)出{ name: 'Ben', year: 1972 } 這個(gè)document,請(qǐng)注意:只要sub document
1 回答

慕絲7291255
TA貢獻(xiàn)1859條經(jīng)驗(yàn) 獲得超6個(gè)贊
11) $elemMatch
如果對(duì)象有一個(gè)元素是數(shù)組,那么$elemMatch可以匹配內(nèi)數(shù)組內(nèi)的元素:
> 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 } } 所有的條件都要匹配上才行。注意,上面的語(yǔ)句和下面是不一樣的。
> t.find( { "x.a" : 1, "x.b" : { $gt : 1 } } )
$elemMatch是匹配{ "a" : 1, "b" : 3 },而后面一句是匹配{ "b" : 99 }, { "a" : 11 }
- 1 回答
- 0 關(guān)注
- 1475 瀏覽
添加回答
舉報(bào)
0/150
提交
取消