java - QueryDSL多参数搜索,当值为空时构建查询跳过谓词
问题描述
我正在使用 QueryDSL JPA 开发 Spring Boot Web 应用程序。我有一个 REST api,我可以在其中获取用户的表单输入。我必须执行多参数搜索。如果 users inpu 的值为 null(这没关系,因为并非所有字段都需要),我的查询构建器在查询数据库时应该跳过这个值。
在我的 QueryDSL 部分,我得到一个对象,例如“解决方案”,它可能如下所示:
ticketNumber: 4261 (Integer)
errorFlag: false (Boolean)
statusOCIA: null (string)
description: "Erorr while click an image" (String)
我尝试使用 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 是“描述”,它应该执行 searchSolution.getDescription。
我尝试了一些使用 HashMap 或 ArrayList 的东西,但由于对象中的数据类型不同而失败。
我希望有一个人可以帮助我。
解决方案
尝试将此检查放在 if 条件中
entityPath.get(attr.getName()) != null
让它
if (entityPath.get(attr.getName()) != null) {
builder.or(QentityPath.get(attr.getName()).eq(entityPath.get(attr.getName())));
}
推荐阅读
- javascript - 如何修复旨在为时间戳添加分钟的波纹管代码,并且最终值也应该在时间戳中,因为我将进行一些数据库查询?
- android - 如何将图像添加到 ExtendedFloatingActionButton(除了图标)?
- xquery - “cts.values”和“cts.elementValues”的比较
- automation - GetAsTable 问题 - Intellibot RPA
- laravel - 连接到本地 mysql 服务器的 Docker 容器化 Laravel 应用程序
- laravel - 不带问号的 Swagger 参数查询
- json - SyntaxError: JSON.parse: 数组元素后的预期 ',' 或 ']'
- unidata - 用 Unidata 替换列表值
- c++ - 将元素存储在作为指针的数组中
- python - 如何在python中获得数值导数函数?