2

有没有办法根据查询表达式的条件向查询添加多个过滤器。

例如,类似的东西。

AddressFluentHelper queryHelper=service.getAllAddress;
if(zipCode!=null){
   queryHelper.filter(Address.ZIPCODE.eq(zipCode))
}
if(street!=null){
   queryHelper.filter(Address.STREET.eq(street))
}

如果允许,不同过滤器之间的默认条件是“AND”吗?如果默认是'AND'我们如何实现'OR'的用例

4

1 回答 1

2

默认行为是所有给定的 'AND' 连接FilterExpression

为了使这一点更明确以及允许“或”连接,您可以考虑构建FilterExpression“外部”,例如:

import io.vavr.collection.List;
...
List<ExpressionFluentHelper<YOUR_ENTITY>> expressions = List.empty();
if (zipCode != null) {
    expressions = expressions.append(Address.ZIPCODE.eq(zipCode););
}
if (street != null) {
    expressions = expressions.append(Address.STREET.eq(street));
}

AddressFluentHelper queryHelper = service.getAllAddress();
if (!expressions.isEmpty()) {
    // this combines all elements in the "expressions" via "or", starting from the left/the first entry 
    ExpressionFluentHelper<YOUR_ENTITY> combinedExpression = expressions.reduceLeft(ExpressionFluentHelper::or);
    queryHelper.filter(combinedExpression);
}
于 2019-08-04T19:26:44.780 回答