gpt4 book ai didi

Spring JPA ExampleMatcher比较日期条件

转载 作者:行者123 更新时间:2023-12-03 13:32:05 25 4
gpt4 key购买 nike

我正在使用Spring JPA,并通过使用示例匹配器获取数据列表。
源代码如下:

public Page<TranxLog> findAllByConditions(TranxReportFormModel formModel, Pageable page) {
ExampleMatcher matcher = ExampleMatcher.matching()
.withNullHandler(ExampleMatcher.NullHandler.IGNORE)
.withStringMatcher(ExampleMatcher.StringMatcher.CONTAINING)
.withIgnoreCase()
.withIgnoreNullValues();
Example<TranxLog> example = Example.of(formModel.getTranxLog(), matcher);
return tranxlogRepository.findAll(example, page);
}

现在,我有了搜索页面,其中包含 formDatetoDate,必须将其与 DateTime中的字段 TranxLog进行比较。
我尝试使用 .withMatcher(),但找不到比较日期的方法。

任何想法?谢谢。

最佳答案

您也可以从JpaSpecificationExecutor进行扩展,并从Example中获取带有QueryByExamplePredicateBuilder的谓词。

在您的存储库中:

public interface TranxlogRepository extends JpaRepository<Tranxlog, Long>, JpaSpecificationExecutor<Tranxlog>{ 
}

为您服务
public Specification<TranxLog> getSpecFromDatesAndExample(
LocalDateTime from, LocalDateTime to, Example<TranxLog> example) {

return (Specification<TranxLog>) (root, query, builder) -> {
final List<Predicate> predicates = new ArrayList<>();

if (from != null) {
predicates.add(builder.greaterThan(root.get("dateField"), from));
}
if (to != null) {
predicates.add(builder.lessThan(root.get("dateField"), to));
}
predicates.add(QueryByExamplePredicateBuilder.getPredicate(root, builder, example));

return builder.and(predicates.toArray(new Predicate[predicates.size()]));
}
};

在您的serviceImp中:
public Page<TranxLog> findAllByConditions(TranxReportFormModel formModel, Pageable page) {
ExampleMatcher matcher = ExampleMatcher.matching()
.withNullHandler(ExampleMatcher.NullHandler.IGNORE)
.withStringMatcher(ExampleMatcher.StringMatcher.CONTAINING)
.withIgnoreCase()
.withIgnoreNullValues();
Example<TranxLog> example = Example.of(formModel.getTranxLog(), matcher);
return tranxlogRepository.findAll(getSpecFromDatesAndExample(from, to, Example.of(formModel.getTranxLog(), matcher)), page);
}

关于Spring JPA ExampleMatcher比较日期条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45973070/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com