java.time YearMonth 作为实体中的一种类型

java.time YearMonth as a type within entity

如何在实体中使用 YearMonth?我已经看到很多关于转换器的堆栈溢出答案?这仍然需要吗?如果需要的话如何?

@Basic(optional = false)
@NotNull
@Column(name = "cc_exp_date")
private YearMonth ccExpDate;

我得到的异常如下。我能否在 set 方法中将其转换为日期,然后在实体的 get 方法中转换回 YearMonth 作为变通方法?

 MysqlDataTruncation: Data truncation: Incorrect date value: '\xAC\xED\x00\x05sr\x00\x0Djava.time.Ser\x95]\x84\xBA\x1B"H\xB2\x0C\x00\x00xpw\x06\x0C\x00\x00\x07\xE2\x02x' for column 'cc_exp_date' at row 1

如果您的 JPA 提供程序没有以合理的方式保留类型(在这种情况下,因为它是 Java8 class,它是在 JPA 2.1 获得批准后添加的,并且因为您重新使用最近没有太多更新来支持更新类型的 EclipseLink),那么您需要定义 JPA 2.1 AttributeConverter 以将其转换为标准的 JPA 可持久类型(在本例中类似于 java.sql.Date ).

其他 JPA 提供程序支持开箱即用地保留此类类型(DataNucleus JPA 当然支持,Hibernate 也可能具有可选的依赖项?)