我的一个实体中有一个 Java 8 LocalTime 。
private final LocalTime departureTime;
它是一个带有 Spring Data Rest 的 Spring Boot 1.3.6 应用程序。我使用 Jsr310JpaConverters 来支持 JPA 的 Java 8 时间模块。
当我将 LocalTime 变量保存到 MySql 时,保存 LocalTime 变量的日期也将保留到数据库中。假设如果我在 2016 年 1 月 1 日保存 18:00:00 ,它会保留为 2016-01-01 18:00:00 。我只想节省时间。即 18:00:00 。有什么解决办法吗?
提前致谢
此示例运行于:java 8、JPA 2.1、Hibernate 4.3.5。
如果您使用 JPA 2.1 和 Hibernate 5.0 版本的早期版本,则可以实现 JPA AttributeConverter:
import java.sql.Time;
import java.time.LocalTime;
import javax.persistence.AttributeConverter;
import javax.persistence.Converter;
/**
* Converter to persist LocalDate and LocalDateTime with
* JPA 2.1 and Hibernate older than 5.0 version
**/
@Converter(autoApply = true)
public class LocalTimeAttributeConverter implements AttributeConverter<LocalTime, Time>{
@Override
public Time convertToDatabaseColumn(LocalTime localTime) {
return (localTime == null ? null : Time.valueOf(localTime));
}
@Override
public LocalTime convertToEntityAttribute(Time time) {
return (time == null ? null : time.toLocalTime());
}
}
或者,如果您使用 Hibernate 5.0(或更高版本),您可以添加 maven 的依赖项:
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-java8</artifactId>
<version>5.1.0.Final</version>
</dependency>
注释 -> 实体的映射是相同的。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)