[英]How to add a comparator to querydsl Predicate?
我有以下 Web 服务,可自动将获取参数查询转换为数据库选择:
public interface PersonRepo extends
JpaRepository<Person, Long>,
QuerydslPredicateExecutor<Person> {
}
@GetMapping
public ResponseEntity getFiltered(
@QuerydslPredicate(root = Person.class) Predicate predicate, Pageable pageable) {
return ResponseEntity.ok(personRepo.findAll(predicate, pageable)));
)
}
例如可以执行以下查询:
GET /people?name=John&age=18
GET /people?name=John&age=18&page=1&sort=name,desc
问题:我想按如下方式应用比较器查询:
GET /people?name=John&age>18
GET /people?name=John&age>18&age<30
GET /people?name=John&age<30
问题:我怎么能做到这一点? 至少后面的查询不起作用。
我通过为该字段定义占位符并使用QuerydslBinderCustomizer
找到了一个解决方案:
public interface PersonRepo extends
JpaRepository<Person, Long>,
QuerydslPredicateExecutor<Person>,
QuerydslBinderCustomizer<Person> {
default void customize(final QuerydslBindings bindings, final QPerson person) {
bindings.bind(cache.ageMin).first((path, value) -> person.age.goe(value));
bindings.bind(cache.ageMax).first((path, value) -> person.age.loe(value));
}
}
当然,年龄字段必须作为临时字段存在,以便 querydsl 知道它们:
@Entity
class Person {
@Transient
@QueryType(PropertyType.NUMERIC)
public int ageMin;
@Transient
@QueryType(PropertyType.NUMERIC)
private int ageMax;
}
您可以使用单个绑定并使用来自Query DSL 值运算符的表达式。
public interface PersonRepo extends
JpaRepository<Person, Long>,
QuerydslPredicateExecutor<Person>,
QuerydslBinderCustomizer<Person> {
default void customize(final QuerydslBindings bindings, final QPerson person) {
bindings.bind(cache.age).all((path, values) -> ExpressionProviderFactory.getPredicate(path, values));
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.