首页 > 解决方案 > 嵌套异常是 java.lang.IllegalArgumentException:参数值 [2020-04-20] 与预期类型不匹配 [java.util.Date (n/a)]]

问题描述

我想发送这个请求 http://localhost:8080/ {url}?start=2020-04-20&end=2020-04-24&status=success&status=failed

在事务模型中

private java.sql.Timestamp addedOn;

我正在尝试为以下博客创建多个过滤器的动态查询: https ://attacomsian.com/blog/spring-data-jpa-specifications

Specs.java 文件 toPredicate 方法

if (criteria.getOperation().equals(SearchOperation.GREATER_THAN)) {
                predicates.add(builder.greaterThan(
                        root.get(criteria.getKey()), criteria.getValue().toString()));
} else if (criteria.getOperation().equals(SearchOperation.LESS_THAN)) {
                predicates.add(builder.lessThan(
                        root.get(criteria.getKey()), criteria.getValue().toString()));
}

这是我的控制器代码

Timestamp start = new Timestamp(dateFormat.parse(request.getParameter("start")).getTime());
Timestamp end = new Timestamp(dateFormat.parse(request.getParameter("end")).getTime());
Specs txnSpecs = new Specs();
txnSpecs.add(new SearchCriteria("addedon", start, SearchOperation.GREATER_THAN_EQUAL));
txnSpecs.add(new SearchCriteria("addedon", end, SearchOperation.LESS_THAN_EQUAL));
txnSpecs.add(new SearchCriteria("status", Arrays.asList(request_params.get("status")), SearchOperation.IN));
List<Transaction> txnList = transactionRepository.findAll(txnSpecs);
return txnList;        

但是当我提出请求时,我得到:

nested exception is java.lang.IllegalArgumentException: Parameter value [2020-04-20] did not match expected type [java.util.Date (n/a)]]

在将 Date 值作为 SQL 查询的参数发送之前,是否需要转换它?或者我需要使用其他类型的日期?

标签: javahibernatespring-data-jpahibernate-criteria

解决方案


Date在将其作为 SQL 查询的参数发送之前,是否需要转换该值?

不,反之亦然,您必须保留它 aDate但您通过调用将其转换为 String criteria.getValue().toString()


推荐阅读