0

我正在尝试通过 Hibernate 4.3.5 API 创建 blob。H2 1.4.190 内存。最初代码是为 Oracle DB 编写的,现在我们正在尝试使用 H2 进行单元测试。

Blob blob = Hibernate.getLobCreator(hibernateSession).createBlob(new byte[]{0});
blob.setBinaryStream(1);

在 createBlob() 堆栈期间如下:

at org.h2.value.ValueLobDb.<init>(ValueLobDb.java:75)
at org.h2.value.ValueLobDb.createSmallLob(ValueLobDb.java:667)
at org.h2.value.ValueLobDb.createSmallLob(ValueLobDb.java:654)
at org.h2.store.LobStorageMap.createBlob(LobStorageMap.java:162)
at org.h2.jdbc.JdbcConnection.createBlob(JdbcConnection.java:1826)
at org.h2.jdbc.JdbcBlob.setBytes(JdbcBlob.java:124)
at org.hibernate.engine.jdbc.ContextualLobCreator.createBlob(ContextualLobCreator.java:68)

并且在构造函数中将精度设置为 1(因为单字节数组用作 createBlob 参数?)。下一个 setBinaryStream(1) 抛出异常。

我做错了什么还是这是 H2 问题?

4

1 回答 1

0

好的,将答案发布给认为有用的人:

显然,正如我在这里被告知的那样:

由于某种原因,Hibernate 似乎没有创建适当空 Blob 的 API,并且在空 Blob 上调用 setBinaryStream 是唯一合法的

所以我不得不:

Blob blob = Hibernate.getLobCreator(hibernateSession).createBlob(new byte[0]); 
blob.setBinaryStream(1); 
于 2016-01-09T14:39:16.983 回答