如果参数在 Spring Data JPA 中为 null,则忽略条件

Ignoring condition if the parameter is null in Spring Data JPA

我目前正在开发我的项目的搜索和过滤功能。我正在尝试使用此请求正文检索数据:

{
    "researchers": [
        "Jhon Doe"
    ],
    "unit": null,
    "agency":null,
    "date": null,
    "status": null,
    "budget": null
}

以下是 ReasearchRepository 中检索此数据的方法:


    @Query("select r from Research r " +
            "left join r.fundingAgencies fundingAgencies " +
            "left join r.researchers researchers " +
            "where (:budgetStart is null or :budgetEnd is null or  r.budget between :budgetStart and :budgetEnd )" +
            "and (:startDate is null or r.startDate >= :startDate) " +
            "and (:endDate is null or r.endDate <= :endDate) " +
            "and (:agencyNames is null or fundingAgencies.agencyName in :agencyNames) " +
            "and (:unitNames is null or r.deliveryUnit.unitName in :unitNames )" +
            "and (:names is null or researchers.name in :names ) " +
            "and (:researchStatuses is null or r.researchStatus in :researchStatuses)")
    List<Research> findAdvanced( @Param("budgetStart") Double budgetStart,
                                 @Param("budgetEnd")  Double budgetEnd,
                                 @Param("startDate")  LocalDate startDate,
                                 @Param("endDate") LocalDate endDate,
                                 @Param("agencyNames") Collection<String> agencyNames,
                                 @Param("unitNames") Collection<String> unitNames,
                                 @Param("names") Collection<String> names,
                                 @Param("researchStatuses") Collection<ResearchStatus> researchStatuses);

我的问题是,当我尝试从请求中的给定值中查找数据时,它 return 是一个空列表 [],即使它存在于数据库。我想要实现的是,如果参数为空,它将忽略查询中的特定条件,并且仍然 return data.

我刚刚关注了 Baeldung 的文章。

我还找到了另一篇关于使用 Criteria 的文章 API,但我要花很多时间才能理解它。我的项目有点仓促。

TIA

我似乎是使用规范的好案例。

https://spring.io/blog/2011/04/26/advanced-spring-data-jpa-specifications-and-querydsl/