1

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

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”的文档?

4

1 回答 1

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 } ] }
于 2013-05-09T15:28:55.780 回答