Почему я получаю org.hibernate.HibernateException: IOException произошло чтение двоичного значения

Я нашел это исключение в своих журналах, я никогда его раньше не видел, я использую Hibernate 4.1.7.

Означает ли это, что моя база данных повреждена, или это ошибка в Hibernate. Я нашел ссылку на эту ошибку по адресу http://lists.jboss.org/pipermail/hibernate-issues/2010-November/026487.html, но это относилось к более ранней версии hibernate и было исправлено для Hibernate 4.0.

org.hiorg.hibernate.HibernateException: IOException occurred reading a binary value
    at org.hibernate.type.descriptor.java.DataHelper.extractBytes(DataHelper.java:187)
    at org.hibernate.type.descriptor.java.PrimitiveByteArrayTypeDescriptor.wrap(PrimitiveByteArrayTypeDescriptor.java:124)
    at org.hibernate.type.descriptor.java.PrimitiveByteArrayTypeDescriptor.wrap(PrimitiveByteArrayTypeDescriptor.java:41)
    at org.hibernate.type.descriptor.sql.BlobTypeDescriptor$5.doExtract(BlobTypeDescriptor.java:118)
    at org.hibernate.type.descriptor.sql.BasicExtractor.extract(BasicExtractor.java:65)
    at org.hibernate.type.AbstractStandardBasicType.nullSafeGet(AbstractStandardBasicType.java:269)
    at org.hibernate.type.AbstractStandardBasicType.nullSafeGet(AbstractStandardBasicType.java:265)
    at org.hibernate.type.AbstractStandardBasicType.nullSafeGet(AbstractStandardBasicType.java:238)
    at org.hibernate.type.AbstractStandardBasicType.hydrate(AbstractStandardBasicType.java:357)
    at org.hibernate.persister.entity.AbstractEntityPersister.hydrate(AbstractEntityPersister.java:2807)
    at org.hibernate.loader.Loader.loadFromResultSet(Loader.java:1545)
    at org.hibernate.loader.Loader.instanceNotYetLoaded(Loader.java:1477)
    at org.hibernate.loader.Loader.getRow(Loader.java:1377)
    at org.hibernate.loader.Loader.getRowFromResultSet(Loader.java:644)
    at org.hibernate.loader.Loader.doQuery(Loader.java:854)
    at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:293)
    at org.hibernate.loader.Loader.doList(Loader.java:2382)
    at org.hibernate.loader.Loader.doList(Loader.java:2368)
    at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2198)
    at org.hibernate.loader.Loader.list(Loader.java:2193)
    at org.hibernate.loader.criteria.CriteriaLoader.list(CriteriaLoader.java:122)
    at org.hibernate.internal.SessionImpl.list(SessionImpl.java:1618)
    at org.hibernate.internal.CriteriaImpl.list(CriteriaImpl.java:374)
    at com.jthink.songkong.db.SongCache.loadSongsFromDatabase(SongCache.java:57)
    at com.jthink.songkong.analyse.analyser.SongGroup.getSongs(SongGroup.java:48)
    at com.jthink.songkong.analyse.analyser.DiscogsSongGroupMatcher.call(DiscogsSongGroupMatcher.java:63)
    at com.jthink.songkong.analyse.analyser.DiscogsSongGroupMatcher.call(DiscogsSongGroupMatcher.java:28)
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
    at java.util.concurrent.FutureTask.run(FutureTask.java:166)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    at java.lang.Thread.run(Thread.java:722)
Caused by: java.io.IOException: org.h2.jdbc.JdbcSQLException: IO Exception: "Missing lob entry: 5587/4" [90028-172]
    at org.h2.message.DbException.convertToIOException(DbException.java:348)
    at org.h2.store.LobStorageBackend$LobInputStream.fillBuffer(LobStorageBackend.java:695)
    at org.h2.store.LobStorageBackend$LobInputStream.readFully(LobStorageBackend.java:668)
    at org.h2.store.LobStorageBackend$LobInputStream.read(LobStorageBackend.java:654)
    at org.hibernate.type.descriptor.java.DataHelper.extractBytes(DataHelper.java:179)
    ... 31 more
Caused by: org.h2.jdbc.JdbcSQLException: IO Exception: "Missing lob entry: 5587/4" [90028-172]
    at org.h2.message.DbException.getJdbcSQLException(DbException.java:329)
    at org.h2.message.DbException.get(DbException.java:169)
    at org.h2.message.DbException.get(DbException.java:146)
    at org.h2.store.LobStorageBackend.readBlock(LobStorageBackend.java:203)
    at org.h2.store.LobStorageBackend$LobInputStream.fillBuffer(LobStorageBackend.java:692)
    ... 34 more

person Paul Taylor    schedule 10.09.2013    source источник
comment
Какую базу данных вы используете, вероятно, базу данных h2? Не могли бы вы сообщить мне версию jar h2?   -  person Gyanendra Dwivedi    schedule 12.09.2013


Ответы (3)


Начнем с документа Hibernate:

@Lob indicates that the property should be persisted in a Blob or a Clob depending on the property type: java.sql.Clob, Character[], char[] and java.lang.String will be persisted in a Clob. java.sql.Blob, Byte[], byte[] and serializable type will be persisted in a Blob.

Например:

@Lob
public String getFullText() {
    return fullText;
}

@Lob 
public byte[] getFullCode() {
    return fullCode;
}

Зная это, это может означать, что объекта нет в базе данных. Возможно, он был удален из таблицы, но не в ссылочной таблице. Предположим, что из таблицы Blobs блоб с id 5 был удален, но в таблице users_blobs на него по-прежнему ссылаются следующим образом:

| user_id | blob_id|
|    4    |    5   | //This entry blob were delete but is still referenced by that table
|    5    |    2   | 

Если это так, вам следует переопределить свои ограничения users_blobs (например), чтобы они были удалены, или поставить null, если большой двоичный объект будет удален.

Кроме того, эта ссылка тоже может быть полезной:

http://h2-database.66688.n3.nabble.com/IO-Exception-quot-Missing-lob-entry-1-0-quot-90028-171-припопыткечтения-a-BLOB-longer-than-128-bye-td4026236.html

person JGutierrezC    schedule 18.09.2013
comment
Спасибо, у меня больше не было проблемы, но похоже, что это один из описанных случаев, так что спасибо. - person Paul Taylor; 19.09.2013

Это, безусловно, проблема с базой данных, а не со спящим режимом. Вы должны посмотреть на причину исключения, которое возникает внутри h2 кода базы данных.

Caused by: org.h2.jdbc.JdbcSQLException: IO Exception: "Missing lob entry: 5587/4" [90028-172]
    at org.h2.message.DbException.getJdbcSQLException(DbException.java:329)
    at org.h2.message.DbException.get(DbException.java:169)
    at org.h2.message.DbException.get(DbException.java:146)
    at org.h2.store.LobStorageBackend.readBlock(LobStorageBackend.java:203)
    at org.h2.store.LobStorageBackend$LobInputStream.fillBuffer(LobStorageBackend.java:692)

Поиск в Интернете по запросу «h2 database Missing Lob Entry» показывает, что это сообщение об ошибке, специфичное для h2, и ответы, подобные этому: https://groups.google.com/forum/#!topic/h2-database/xey-czIhocM указывают на то, что база данных, скорее всего, повреждена.

Если это происходит чаще, было бы уместно провести дополнительные исследования о том, как это произошло. Но лучше всего это делается в той h2 группе, где активны разработчики базы данных.

person Holger    schedule 18.09.2013
comment
Спасибо за указание на то, что основной проблемой может быть h2, и за предоставление ссылки. - person Paul Taylor; 19.09.2013

Похоже, вы пытаетесь загрузить регистр данных, который уже был удален, попробуйте синхронизировать доступ к этому спящему DAO. Многопоточные приложения должны использовать одно соединение на поток.

person Raul Lapeira Herrero    schedule 18.09.2013
comment
Я не понимаю, чем принятый ответ лучше моего. Проблема никак не связана с типом Blob или аннотациями: E это может произойти и с другими типами. - person Raul Lapeira Herrero; 18.10.2013