您如何在 Spring 引导中编写存储库查询以通过关联键进行过滤?

How do you write a repository query in Spring boot to filter by an association key?

如何在存储库界面中编写查询以执行 WHERE assoc_id = :key?

我有一个名为 CmsImpacts 的实体,然后我有一个调用 ImpactsRepository 的服务,如下所示:

    import java.util.List;
    
    public interface ImpactsRepository<T extends CmsImpacts> extends BaseCmsRepository<CmsImpacts> {
        
        @Query("SELECT a FROM #{#entityName} a where a.scenarioId = :scenarioId")
        List<CmsImpacts> getByScenarioPaged(
                Integer scenarioId,
                Pageable pageable
        );
        
        @Query("SELECT COUNT(a.id) FROM #{#entityName} a where a.scenarioId = :scenarioId")
        Integer getAsScenarioCount(
                Integer scenarioId
        );
        
        
        
    }

这种关系的要点是 CmsScenariosCmsImpacts 上的一对多关系。实体关系定义为:

    
    @JsonIgnore
    @JsonBackReference
    @JoinColumn(name = "scenario_id", referencedColumnName = "id")
    @ManyToOne(optional = false, fetch = FetchType.LAZY)
    private CmsScenarios scenarioId;

每当我调用我的服务并传入 scenario_id 的 Integer 值时,它都会抛出 TypeException,因为(理所当然)需要 CmsScenario 对象,而不是 Integer。

错误消息:2020-11-04 15:10:45.764 错误 128396 --- [io-8080-exec-18] o.s.b.w.servlet.support.ErrorPageFilter :由于异常 [org.springframework.dao.InvalidDataAccessApiUsageException:从请求 [/api/impacts/list/scenario/2] 转发到错误页面:参数值 [2] 与预期类型 [com.vw.asa.entities.cms.CmsScenarios (n/a)] 不匹配;嵌套异常是 java.lang.IllegalArgumentException:参数值 [2] 与预期类型不匹配 [com.vw.asa.entities.cms.CmsScenarios (n/a)]]

我需要做什么才能执行此查询?这也适用于它上面的查询,即分页计数器。

注:

我不想只检索 CmsScenarios 对象并调用 getImpacts(),那会 return 所有对象,我需要能够对它们进行分页。

您必须添加相关实体的id

@Query("SELECT a FROM #{#entityName} a where a.scenarioId.id = :scenarioId")