關(guān)于IO的問(wèn)題,為什么結(jié)束了將持久化對(duì)象保存到數(shù)據(jù)庫(kù)最后關(guān)掉了inputstream會(huì)導(dǎo)致錯(cuò)誤。
public?void?testSavePicture()?{ SimpleDateFormat?sdf?=?new?SimpleDateFormat("yyyy-MM-dd"); Date?date; try?{ date?=?sdf.parse("1987-04-01"); Student?s?=?new?Student(0,?"kula",?date); File?file?=?new?File("/Users/kk/Desktop/photo/3.pic.jpg"); InputStream?in?=?new?FileInputStream(file); Blob?image?=?Hibernate.getLobCreator(session).createBlob(in,?in.available()); s.setPicture(image); session.save(s); //in.close();?如果關(guān)掉輸入流會(huì)報(bào)錯(cuò)。 }?catch?(ParseException?e)?{ //?TODO?Auto-generated?catch?block e.printStackTrace(); }?catch?(FileNotFoundException?e)?{ //?TODO?Auto-generated?catch?block e.printStackTrace(); }?catch?(IOException?e)?{ //?TODO?Auto-generated?catch?block e.printStackTrace(); } }
如果關(guān)閉了輸入流執(zhí)行不成功會(huì)報(bào)以下錯(cuò)誤。
avax.persistence.PersistenceException: org.hibernate.exception.GenericJDBCException: could not execute statement
? ? at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:147)
? ? at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:155)
? ? at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:162)
? ? at org.hibernate.internal.SessionImpl.flush(SessionImpl.java:1402)
? ? at org.hibernate.internal.SessionImpl.managedFlush(SessionImpl.java:472)
? ? at org.hibernate.internal.SessionImpl.flushBeforeTransactionCompletion(SessionImpl.java:3132)
? ? at org.hibernate.internal.SessionImpl.beforeTransactionCompletion(SessionImpl.java:2369)
? ? at org.hibernate.engine.jdbc.internal.JdbcCoordinatorImpl.beforeTransactionCompletion(JdbcCoordinatorImpl.java:467)
? ? at org.hibernate.resource.transaction.backend.jdbc.internal.JdbcResourceLocalTransactionCoordinatorImpl.beforeCompletionCallback(JdbcResourceLocalTransactionCoordinatorImpl.java:147)
? ? at org.hibernate.resource.transaction.backend.jdbc.internal.JdbcResourceLocalTransactionCoordinatorImpl.access$100(JdbcResourceLocalTransactionCoordinatorImpl.java:38)
? ? at org.hibernate.resource.transaction.backend.jdbc.internal.JdbcResourceLocalTransactionCoordinatorImpl$TransactionDriverControlImpl.commit(JdbcResourceLocalTransactionCoordinatorImpl.java:221)
? ? at org.hibernate.engine.transaction.internal.TransactionImpl.commit(TransactionImpl.java:68)
? ? at junit.StudentTest.destroy(StudentTest.java:120)
? ? at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
? ? at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
? ? at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
? ? at java.lang.reflect.Method.invoke(Method.java:498)
? ? at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
? ? at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
? ? at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
? ? at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:33)
? ? at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271)
? ? at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:70)
? ? at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
? ? at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
? ? at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
? ? at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
? ? at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
? ? at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
? ? at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
? ? at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
? ? at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
? ? at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
? ? at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
? ? at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
? ? at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: org.hibernate.exception.GenericJDBCException: could not execute statement
? ? at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:47)
? ? at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:111)
? ? at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:97)
? ? at org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:207)
? ? at org.hibernate.engine.jdbc.batch.internal.NonBatchingBatch.addToBatch(NonBatchingBatch.java:45)
? ? at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:2934)
? ? at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:3434)
? ? at org.hibernate.action.internal.EntityInsertAction.execute(EntityInsertAction.java:89)
? ? at org.hibernate.engine.spi.ActionQueue.executeActions(ActionQueue.java:560)
? ? at org.hibernate.engine.spi.ActionQueue.executeActions(ActionQueue.java:434)
? ? at org.hibernate.event.internal.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:337)
? ? at org.hibernate.event.internal.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:39)
? ? at org.hibernate.internal.SessionImpl.flush(SessionImpl.java:1396)
? ? ... 32 more
Caused by: java.sql.SQLException: Error reading from InputStream java.io.IOException
? ? at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:957)
? ? at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:896)
? ? at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:885)
? ? at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:860)
? ? at com.mysql.jdbc.PreparedStatement.readblock(PreparedStatement.java:2664)
? ? at com.mysql.jdbc.PreparedStatement.streamToBytes(PreparedStatement.java:4456)
? ? at com.mysql.jdbc.PreparedStatement.fillSendPacket(PreparedStatement.java:2190)
? ? at com.mysql.jdbc.PreparedStatement.executeUpdateInternal(PreparedStatement.java:2052)
? ? at com.mysql.jdbc.PreparedStatement.executeUpdateInternal(PreparedStatement.java:2009)
? ? at com.mysql.jdbc.PreparedStatement.executeLargeUpdate(PreparedStatement.java:5094)
? ? at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1994)
? ? at org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:204)
? ? ... 41 more
Caused by: java.io.IOException: Stream Closed
? ? at java.io.FileInputStream.readBytes(Native Method)
? ? at java.io.FileInputStream.read(FileInputStream.java:255)
? ? at com.mysql.jdbc.PreparedStatement.readblock(PreparedStatement.java:2662)
? ? ... 48 more
可是io不是應(yīng)該在用完后就關(guān)掉嗎。
2016-07-04
這個(gè)沒(méi)法解釋取出照片關(guān)閉了io,能正常通過(guò)。
以上代碼可以執(zhí)行。
2016-07-04
session保存對(duì)象并不是調(diào)用session.save之后立即寫(xiě)入到數(shù)據(jù)庫(kù)中,而是等待提交事務(wù)的時(shí)候才會(huì)寫(xiě)入到數(shù)據(jù)庫(kù)中