【发布时间】:2018-04-05 19:33:00
【问题描述】:
问题:带有 Spring Data 返回日期的本机查询返回 java.sql.Date 而不是 java.time.LocalDate,尽管进行了设置。
上下文:一个带有 Spring Boot 2.0.0.M5(最新)、Hibernate 5.2.11、Hibernate-Java8 5.2.12(只要它在类路径上就支持 JSR310 类)的新项目。
下面的匿名示例(该应用与生日无关):
public interface BirthdayRepository<T, ID extends Serializable> extends Repository<T, ID> {
@Query(value = "select day from birthdays", nativeQuery = true)
Iterable<java.sql.Date> getBirthdays(); //the return type should ideally be java.time.LocalDate
}
在数据库(SQL Server)中,day 字段为 DATE,值类似于 2017-10-24。
问题是在运行时,Spring Data 存储库(我无法控制其实现,或者有办法吗?)返回 java.sql.Date 而不是 java.time.LocalDate (澄清:返回类型似乎是由 Spring Data 决定的,即使我将返回类型更改为 java.time.LocalDate,也仍然是 java.sql.Date,这是我开始的方式。
没有办法直接得到LocalDate吗?我可以稍后转换它,但是(1)效率低下,(2)存储库方法必须返回旧的日期/时间类,这是我想避免的。我阅读了 Spring Data documentation,但没有任何内容。
编辑:对于任何有同样问题的人,下面是解决方案,Jens 建议的转换器。
public class LocalDateTypeConverter {
@Converter(autoApply = true)
public static class LocalDateConverter implements AttributeConverter<LocalDate, Date> {
@Nullable
@Override
public Date convertToDatabaseColumn(LocalDate date) {
return date == null ? null : new Date(LocalDateToDateConverter.INSTANCE.convert(date).getTime());
}
@Nullable
@Override
public LocalDate convertToEntityAttribute(Date date) {
return date == null ? null : DateToLocalDateConverter.INSTANCE.convert(date);
}
}
【问题讨论】:
-
我很困惑。你在你的界面中指定了你想要的
Iterable<java.sql.Date>为什么你还期待别的?为什么“存储库方法必须返回旧的日期/时间类?” -
这就是 Spring Data 返回的内容。如果我输入 LocalDate (我最初这样做),当我从迭代器中检索项目时,它会在运行时失败并出现 ClassCastException。这就是为什么我发表评论的原因,类型应该是。我将补充说明。
标签: spring-data spring-data-jpa hibernate-5.x localdate jsr310