package com.boldseas.porscheshop.common.config; import javax.persistence.AttributeConverter; import javax.persistence.Converter; import java.sql.Timestamp; import java.time.LocalDateTime; /** * Jpa支持LocalDateTime類型持久化 * @author feng * @version 2018/5/12 */ @Converter(autoApply = true) public class LocalDateTimeAttributeConverter implements AttributeConverter<LocalDateTime, Timestamp> { @Override public Timestamp convertToDatabaseColumn(LocalDateTime locDateTime) { return (locDateTime == null ? null : Timestamp.valueOf(locDateTime)); } @Override public LocalDateTime convertToEntityAttribute(Timestamp sqlTimestamp) { return (sqlTimestamp == null ? null : sqlTimestamp.toLocalDateTime()); } }
java8帶來了不少新特性,其中最重要的一個特性就是新的時間和日期API。老的時間日期API存在不少問題,不過在java8中這些特性將不復存在。可是,JPA會把LocalDate和LocalDateTime映射成 BLOB類型,而不是 DATE或 TIMESTAMP。java
爲何JPA不支持LocalDate 和LocalDateTime?sql
由於JPA2.1版本在java8以前發佈,所以@Temporal註解只能用在java.util.Date和java.util.Calendar屬性上。ide
想要在JPA中使用LocalDate 和LocalDateTime,能夠實現Attribute Converter.spa