微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – Spring – QueryDsl支持的高级比较器

official documentation之后,将@EnableSpringDataWebSupport注释添加到我的Spring配置允许在查询自动注入Predicate类:

@RequestMapping(method = RequestMethod.GET,path="/find")
public ResponseEntity

然后我可以在执行GET请求时轻松搜索

GET /foo/name?=bob&name=alice&age=20

这很好用.但是我想知道如何实现更高级的搜索条件:

>>
><
>> =
>< =
通常,我想将这些运算符应用于数据模型中的数字和日期字段. Querydsl支持这些标准.

我尝试添加> (>)在我的查询参数中,但它无法解析(例如,对于数字字段,如年龄,它抱怨它不能解析> 10作为数字.

是否可以在查询中直接使用此运算符?

(如果重要的话我正在使用Spring Data Mongodb)

最佳答案
自定义查询DSL绑定 – 大于比较

您可以做的是通过扩展QueryDslPredicateExecutor和QuerydslBinderCustomizer在您的存储库中定义您自己的QueryDSL Binding:

public interface FooRepository
        extends CrudRepositoryirst(singleBinding);
    }
}

我不是查询DSL专家,但我的理解如下:

a binding defines how a specific field is to be compared to its
database column.

与java 8 lambda相同的绑定:(path,ageValue) – > path.gt(ageValue).您必须从url参数的角度阅读customize方法中的代码

fetch the Foos for which the age provided as parameter is greater than
the database’s value.

自定义查询DSL绑定 – 比较之间

另一种选择是为参数提供下限和上限,如下所示:?age = 10& age = 30.然后,定义以下绑定:

default void customize(final QuerydslBindings bindings,final QFoo foo) {
    bindings.bind(foo.age).all((path,ageValue) -> {
        Iteratorterator();
        return path.between(it.next(),it.next());
    });
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐