2014-12-02 47 views
1

我有一个具有以下记录结构的MongoDB记录。

{ 
    "_id" : ObjectId("547e29f2421aa9302705679a"), 
    "runs" : [ 
     { 
      "datetime" : "2014-04-2813:18:54.959579", 
      "tag" : "v1.0", 
     }, 
     { 
      "datetime" : "2014-11-1122:45:13.841787", 
      "tag" : "v1.1", 
     } 
    ], 
    "person1" : "person1_id", 
    "person2" : "person2_id" 
} 

我的一些记录将有一个不同的tag或多或少runs,每个。我想制定一个查询,告诉我哪些记录有runtag=v1.1不是 a runtag=v1.0

我刚开始学的MongoDB,但我已经拿出查询:

db.mycollection.find({ $and: [ 
    { runs : { $elemMatch : { tag : 'v1.1' } } }, 
    { runs : { $elemMatch : { $ne: { tag : 'v1.0' } } } }, 
]}) 

然而,这仍然返回记录与tag=v1.0。我不确定我在哪里错了。 任何人都可以指出我正确的方向吗?

回答

1

你不需要$elemMatch那里,可以发射直接count()。仅当您想要updateproject数组元素时才使用$elemMatch

db.mycollection.count({$and:[{"runs.tag":"v1.1"}, 
        {"runs.tag":{$not:{"$eq":"v1.0"}}}]}) 

find()

db.mycollection.find({$and:[{"runs.tag":"v1.1"}, 
        {"runs.tag":{$not:{"$eq":"v1.0"}}}]}) 
+1

甚至比我张贴的更好的解决方案。公认! – Brett 2014-12-02 23:34:24

1

我发现在正确的地方使用$not的伎俩。

db.mycollection.find({ $and: [ 
    { runs : { $elemMatch : { tag : 'v1.1' } } }, 
    { runs : { $not: { $elemMatch : { tag : 'v1.0' } } } }, 
]}).count()