Mongodb:找到缺少某些键的嵌入式元素

时间:2013-05-09 14:12:06

标签: mongodb

我有一个带有嵌入式集合的文档,但很少有元素缺少一个键,我必须找到所有这些元素。这是一个例子:

var foo = {name: 'foo', embedded: [{myKey: "1", value: 3}, {myKey: "2", value: 3}]}
db.example.insert(foo)
var bar = {name: 'bar', embedded: [{value: 4}, {myKey: "3", value: 1}]}
db.example.insert(bar)

我需要一个返回'bar'对象的查询,因为其中一个嵌入的对象没有'myKey'键。

我尝试使用$exists,但只有当所有嵌入的元素都缺少键时它才会返回

db.example.find({'embedded.myKey': {$exists: true}}).size()
// -> 2
db.example.find({'embedded.myKey': {$exists: false}}).size()
// -> 0

如何找到至少有一个嵌入元素缺少“myKey”键的文档?

1 个答案:

答案 0 :(得分:2)

如果始终存在'value',则可以尝试此命令

db.example.find({ embedded : { $elemMatch : { value : {$exists : true},  myKey : {$exists : false}}  }})
{ "_id" : ObjectId("518bbccbc9e49428608691b0"), "name" : "bar", "embedded" : [ { "value" : 4 }, { "myKey" : "3", "value" : 1 } ] }