Spring数据jpa动态查询不适用于Date类型参数

时间:2017-06-23 14:55:36

标签: postgresql spring-data-jpa

我使用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)),它会抛出异常。

1 个答案:

答案 0 :(得分:0)

不,您要传递Stringjava.sql.Date