java - 基于嵌套文档的可用部分数据进行查询(在morphia、mongoDB中)

标签 java mongodb morphia mongodb-java

文档结构(仅供说明)

员工

{
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/

相关文章:

mongodb - Morphia 在性能方面 fetch 和 asList 之间有区别吗

java - Scala中的排序方法

Java:发送POSTcurl命令在slack中发送消息

python - 如何修复 "' str' object does not support item assignment"在 MongoDb 中的错误?

java - 如何创建 10 个字符长度的 Mongo ObjectId(如 Parse Server)

mongodb - Groovy 找不到匹配的构造函数?

java - 如何在 Java 8 中使用参数调用方法?

java - Quartz 调度作业异常

MongoDB Driver 2.0 C# 有没有办法找出服务器是否关闭?在新的驱动程序中我们如何运行 Ping 命令?

javascript - 如何将 NOT (A AND B) 转换为 mongodb 查询