2

所以,我要做的是查询所有具有“巴黎”城市“法国”状态的文档。我需要进行某种连接,但我无法弄清楚如何构建它。

我正在使用 c# 驱动程序,但我很乐意接受任何方法的帮助。

{
    "_id" : ObjectId("519b407f3c22a73a7c29269f"),
    "DocumentID" : "1",
    "Meta" : [{
        "Name" : "City",
        "Value" : "Paris",
    }, {
        "Name" : "State",
        "Value" : "France",
    }
    }]
}

{
    "_id" : ObjectId("519b407f3c22a73a7c29269g"),
    "DocumentID" : "2",
    "Meta" : [{
        "Name" : "City",
        "Value" : "Paris",
    }, {
        "Name" : "State",
        "Value" : "Texas",
    }
    }]
}
4

2 回答 2

5

$elemMatch运算符用于指示其中的所有条件必须由相同的数组元素匹配。所以(切换到 shell 语法)匹配所有具有元城市 Paris 的文档,你会做

db.collection.find( {Meta:{$elemMatch:{Name:"City",Value:"Paris"}}} )

这可以确保您不会将其数组中某处具有名称:“somethingelse”,值:“巴黎”的东西与匹配名称:“城市”的不同数组元素匹配。

现在,组合查询条件的默认组合是“and”,因此您可以继续添加属性:

db.collection.find( {Meta: {
                       $elemMatch:{Name:"City",Value:"Paris"}, 
                       $elemMatch:{Name:"State",Value:"France"} 
      }
  } 
)

现在,如果您想添加另一个条件,则继续添加它,但如果您想要 NOT,那么您可以这样做:

db.collection.find( {Meta: {
                       $elemMatch:{Name:"City",Value:"Paris"}, 
                       $elemMatch:{Name:"State",Value:"France"},
                       $not: {$elemMatch:{Name:"Arrondissement",Value:"Louvre"}}
      }
  } 
)
于 2013-05-21T14:22:28.013 回答
0

可能会在这里回答我自己的问题,但我是 MongoDB 的新手,所以虽然这似乎给了我想要的结果,但它可能不是最佳方法。

var result = collection.Find(
   Query.And(
   Query.ElemMatch("Meta", Query.EQ("Name", "City")),
   Query.ElemMatch("Meta", Query.EQ("Value", "Paris")),
   Query.ElemMatch("Meta", Query.EQ("Name", "State")),
   Query.ElemMatch("Meta", Query.EQ("Value", "France")))
   );

这导致了跟进 - 我将如何获取“城市”为“巴黎”且“州”为“法国”但其“区”不是“卢浮宫”的所有文件?

于 2013-05-21T13:15:47.217 回答