我在持久化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()
之前的调试屏幕截图
如果我将列类型更改为DATE,则错误会更改为以下内容:
java.lang.IllegalArgumentException: aced00057372000d6a6176612e74696d652e536572955d84ba1b2248b20c00007870770703000007e2060c78
at org.h2.util.DateTimeUtils.parseDateValue(DateTimeUtils.java:313) ~[h2-1.4.196.jar:1.4.196]
答案 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支持的标志,因为这应该是存储值的最后手段。要么,没有支持,要么没有正确配置。在任何一种情况下,您都必须重新检查环境。