QueryDSL多参数搜索,当值为null时构建查询跳过谓词

时间:2019-06-03 08:48:29

标签: java spring spring-boot jpa querydsl

我正在使用QueryDSL JPA开发Spring Boot Web应用程序。 我有一个REST API,我从用户那里获取表单输入。我必须执行多参数搜索。如果用户inpu的值为null(可以,因为并非所有字段都需要输入),则我的查询生成器应在查询数据库时跳过此值。

在我的QueryDSL部分,我得到一个对象,例如“ Solution”,它可能看起来像这样:

机票编号:4261(整数)
errorFlag:false(布尔值)
statusOCIA:空(字符串)
说明:“单击图像时出现错误”(字符串)

我尝试使用QueryDSL的PathBuilder和BooleanBuilder动态构建查询:

    public List<Solution> findSolutionBySolutionQuerydsl(Solution searchSolution) {


    QSolution solution = QSolution.solution;
    JPAQuery<?> query = new JPAQuery<Void>(em);


    BooleanBuilder builder = new BooleanBuilder();
    PathBuilder<QSolution> QentityPath = new PathBuilder<QSolution>(QSolution.class, "solution");
    PathBuilder<Solution> entityPath = new PathBuilder<Solution>(Solution.class, "serachSolution");

    Field[] fields = searchSolution.getClass().getDeclaredFields();


    for (Field attr : fields) {

        if (searchSolution."here it should perform searchSolution.getTicketNumber or searchSolution.getDiscription depending on what attr.getName is"  != null) {
            builder.or(QentityPath.get(attr.getName()).eq(entityPath.get(attr.getName())));

        }
    }

    List<Solution> s1 = query.select(solution)
            .from(solution)
            .where(builder)
            .fetch();

    System.out.println(("query: " + s1));

    return s1;

}

我希望它可以像这样工作:如果attr.getName是“ description”,则应执行searchSolution.getDescription。

我尝试使用HashMap或ArrayList进行操作,但是由于对象中的数据类型不同而失败。

我希望有人能帮助我。

1 个答案:

答案 0 :(得分:0)

尝试将此检查置于if条件

entityPath.get(attr.getName()) != null

做到

if (entityPath.get(attr.getName()) != null) {

    builder.or(QentityPath.get(attr.getName()).eq(entityPath.get(attr.getName())));
}
相关问题