spring-data - 最新的 Spring Data/Hibernate 的 native 查询不支持 java.time.LocalDate?

标签 spring-data spring-data-jpa hibernate-5.x localdate jsr310

问题:尽管进行了设置,但使用 Spring Data 返回日期的 native 查询返回 java.sql.Date 而不是 java.time.LocalDate。

上下文:一个新项目,包含 Spring Boot 2.0.0.M5(最新)、Hibernate 5.2.11、Hibernate-Java8 5.2.12(只要 JSR310 类位于类路径上,它就提供对 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)中,日期字段是 DATE,值类似于 2017-10-24。

问题是在运行时,Spring Data存储库(我无法控制其实现,或者有办法吗?)返回java.sql.Date 不是 java.time.LocalDate (澄清:返回类型似乎由 Spring Data 决定,并且即使我更改了 java.sql.Date返回类型为 java.time.LocalDate,这就是我开始的方式)。

有没有办法直接获取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);
        }
    }

最佳答案

您似乎在转换器中发现了间隙。 Spring Data 在 java.util.Date 之间开箱即用地进行转换和java.time.LocalDate但不在 java.time.LocalDate 之间和java.sql.Date以及 java.sql 中的其他日期和时间相关类型包。

您可以创建自己的转换器来执行此操作。您可以使用Jsr310JpaConverters作为模板。

此外,您可能想要创建功能请求,如果您构建了一个供您使用的转换器,您甚至可以提交拉取请求。

关于spring-data - 最新的 Spring Data/Hibernate 的 native 查询不支持 java.time.LocalDate?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46920073/

相关文章:

java - 如何使用Spring操作生产数据库数据格式?

spring - 错误,Spring NamedJdbcTemplate 中缺少什么

java - 如何在 Spring Data 中按升序对一列进行排序,对另一列进行降序排序?

hibernate - 带有分页的 Spring JPA 存储库中的自定义查询

java - Spring 数据 JPA。查找方式

java - 从 Hibernate 4.3.6 迁移到 Hibernate 5

java - Spring Data jdbc 中的 Map<String, String> 单列映射

java - Spring JPA Repository 动态查询

java - 异常线程 "main"java.lang.IllegalArgumentException : org. hibernate.hql.internal.ast.QuerySyntaxException 得到这个 Excdption

java - hibernate 和 Spring : Exception when trying to create a transaction