gpt4 book ai didi

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

转载 作者:太空宇宙 更新时间:2023-11-04 08:19:15 24 4
gpt4 key购买 nike

文档结构(仅供说明)

员工

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

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com