首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SpringData MongoDB存储库查询嵌套对象中的多个字段

SpringData MongoDB存储库查询嵌套对象中的多个字段
EN

Stack Overflow用户
提问于 2019-01-22 22:11:03
回答 1查看 3.1K关注 0票数 0

我在查询带有两个参数的嵌套对象时遇到了问题。

以下是我的文档:

代码语言:javascript
复制
@Document(collection = "contracts")
public class Contract {
    @Id
    String _id;
    List<Stakeholder> stakeholders;
    Long contractRef;
}

下面是我的嵌套对象:

代码语言:javascript
复制
public class Stakeholder{
    String nationalId;
    String stakeholderRole;
}

我使用mongoRepository来查询这个集合:

代码语言:javascript
复制
public interface ContractRepository extends PagingAndSortingRepository<Contract, String> {
@Query( value = "{'countryBranchCode' : ?0, 'contractRef' : ?1, 'stakeholders' : {'nationalId' : ?2, 'stakeholderRole' : ?3} }",
        fields = "{'stakeholders.$.':1}")
Contract findStakeholderByContractRefAndNationalIdAndStakeholderRole
        (String countryBranchCode, Long contractRef, String nationalId, String stakeholderRole);

基本上,我希望找到一个与contractRef和nationalId和stakeholderRole都匹配的利益相关者的合同。

我尝试了一个更简单的查询:

代码语言:javascript
复制
@Query( value = "{'countryBranchCode' : ?0, 'contractRef' : ?1, 'stakeholders.nationalId' : ?2, 'stakeholders.stakeholderRole' : ?3  }",
        fields = "{'stakeholders.$.':1}")
Contract findStakeholderByContractRefAndNationalIdAndStakeholderRole
        (String countryBranchCode, Long contractRef, String nationalId, String stakeholderRole);

但这可能会返回一个契约,该契约包含一个具有匹配的nationalId和错误角色的涉众,以及另一个具有错误nationalId和良好角色的涉众,因此这不是我想要的。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-01-23 16:42:11

您可以尝试使用$elemMatch

代码语言:javascript
复制
@Query( value = "{'countryBranchCode' : ?0,'contractRef':?1,'stakeholders':{'$elemMatch':{'nationalId':?2,'stakeholderRole':?3}}}",
fields = "{'stakeholders.$.':1}")
Contract findStakeholderByContractRefAndStakeholderRoleAndNationalId (String countryBranchCode, Long contractRef,String stakeholderRole, String nationalId);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54310133

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档