我使用spring数据jpa并生成动态查询我使用Spring Data JPA规范。对于Date类型,它的工作正常。我得到以下例外:
Parameter value [2017-06-01] did not match expected type [java.time.LocalDate (n/a)]; nested exception is java.lang.IllegalArgumentException: Parameter value [2017-06-01] did not match expected type [java.time.LocalDate (n/a)]]
但我传入的参数值是java.util.Date类型。可能是什么原因?
这是我的实体:
private String name;
@Column(name = "user_id")
private Long userId;
@Column(name = "version_id")
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
private Long versionId;
@Column(name = "created_date")
private LocalDate createdDate;
这是
public ViewDetailSpecificationsBuilder createSearchSpecifications(ViewSearch view) {
ViewDetailSpecificationsBuilder builder = new ViewDetailSpecificationsBuilder();
if (StringUtils.isNotBlank(view.getName())) {
builder.with("name", Operation.DEFAULT, view.getName());
}
if (view.getStartDate() != null) {
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
LocalDate date = LocalDate.parse(view.getStartDate(), formatter);
builder.with("createdDate", Operation.GREATHERTHANEQUALTO, date);
}
if (view.getVersion() != null) {
builder.with("version", Operation.DEFAULT, view.getVersion());
}
return builder;
}
这会引发异常:
org.springframework.dao.InvalidDataAccessApiUsageException: Parameter value [Thu%Jun%01%00:00:00%AMT%2017] did not match expected type [java.util.Date (n/a)]; nested exception is java.lang.IllegalArgumentException: Parameter value [Thu%Jun%01%00:00:00%AMT%2017] did not match expected type [java.util.Date (n/a)]
如果我格式化了startDate(formatter.format(startDate)),它会抛出异常。
答案 0 :(得分:0)
不,您要传递String
或java.sql.Date