文档结构(仅供说明)
员工
{
name : "..",
age : ..,
addresses [
{
"street":"...",
"country":{
name:"..",
continent:"..",
Galaxy:".."
}
}
],
company:".."
}
查询-
我只有地址 -> 街道(字符串类型)和地址 -> 国家/地区 -> 名称(字符串类型)。我希望获得符合此条件的所有员工。
Address a1 = new Address();
a1.setStreet("bla bla");
Country c = new Country();
c.setName("sth");
a1.setCountry(c);
Query<Employee> q = ds.createQuery(Employee.class).field("addresses").hasThisElement(a1)
不获取结果(当实际上存在真正的匹配时)。看起来是因为部分“国家/地区”文档匹配。如果我填充国家/地区的所有字段,它会按预期得到结果。
问题#1:上述问题有解决方法吗?
问题#2:地址是一个数组,我可以获得多个(地址#街道,国家/地区#名称)对,并且我再次想要与给定对匹配的员工列表。 像这样的东西:
Query<Employee> q = ds.createQuery(Employee.class).field("addresses").hasThisElement(a1).field("addresses").hasThisElement(a2).field(..) // and so on
注意:我可以分割地址匹配这样的内容
Address a = new Address();
a.setStreet("bla bla");
q.createQuery(Employee.class).field("addresses").hasThisElement(a).field("addresses.country.name").equal("hoo");
但这将匹配地址#1 中的 Employee where street="bla bla"和country.name!="hoo"以及地址#2 中的street!="bla bla"和country.name="hoo"。你明白了。我不希望此类员工被退回。
请告诉我这是否可行。非常感谢。
最佳答案
这是可能的。 MongoDB 有一个特殊的运算符用于处理这种情况,称为 elemMatch。 Morphia 对此有支持。
您认为第二种方法是正确的方法(第一种方法是尝试匹配整个国家/地区,而不是子项),这是正确的。唯一的问题是您希望将其限制为具有 street 和 Country.name 匹配的单个元素。不是具有匹配街道和匹配国家/地区名称的文档。
此文档页面和此线程包含更多信息。
http://code.google.com/p/morphia/wiki/Query
http://groups.google.com/group/morphia/tree/browse_frm/month/2011-02/5bd3f654526fa30b?rnum=41&lnk=ol
不幸的是,我不太了解吗啡,但希望这能为您提供足够的信息来解决这个问题。
关于java - 基于嵌套文档的可用部分数据进行查询(在morphia、mongoDB中),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9883417/