列的值太长 - 错误持久化LocalDate

时间:2018-06-13 15:12:54

标签: java hibernate date java-8

我在持久化LocalDate字段时遇到以下错误[在列中使用VARCHAR(20)类型]:

Value too long for column "BIRTH_DATE VARCHAR(20)":"'aced00057372000d6a6176612e74696d652e536572955d84ba1b2248b20c00007870770703000007e2060c78' (88)";

字段定义如下:

@Column(name = "BIRTH_DATE")
private LocalDate date;
@Column(name = "BIRTH_TIME")
private LocalTime time;

我正在使用spring数据启动器(1.5.9.RELEASE)。其中内部使用hibernate 5.0.12。

根据博文https://www.thoughts-on-java.org/hibernate-5-date-and-time/

Hibernate 5,支持开箱即用的Java 8功能(DateTime API)。那么,为什么会出现这个错误。

我已经检查过,并且正在运行时创建一个有效的LocalDate对象。但是持续存在时会抛出错误。这是调用save()之前的调试屏幕截图 enter image description here

如果我将列类型更改为DATE,则错误会更改为以下内容:

java.lang.IllegalArgumentException: aced00057372000d6a6176612e74696d652e536572955d84ba1b2248b20c00007870770703000007e2060c78
    at org.h2.util.DateTimeUtils.parseDateValue(DateTimeUtils.java:313) ~[h2-1.4.196.jar:1.4.196]

1 个答案:

答案 0 :(得分:10)

您遇到的字符串是序列化对象的十六进制表示形式,可以轻松验证:

ByteArrayInputStream is = new ByteArrayInputStream(new BigInteger(
    "aced00057372000d6a6176612e74696d652e536572955d84ba1b2248b20c00007870770703000007e2060c78", 16)
      .toByteArray());
is.read();
ObjectInputStream ois = new ObjectInputStream(is);
final Object obj = ois.readObject();
System.out.println(obj+" ("+obj.getClass().getName()+')');
2018-06-12 (java.time.LocalDate)

当然,将LocalDate存储为这样的blob并不是真正的DateTime API支持的标志,因为这应该是存储值的最后手段。要么,没有支持,要么没有正确配置。在任何一种情况下,您都必须重新检查环境。