исключение гибернации: не удалось вставить строки коллекции - PullRequest
0 голосов
/ 25 февраля 2012

Я использую hibernate для сопоставления с базой данных. Но столкнулся со следующей ошибкой:

A exec job config finished.
org.hibernate.exception.JDBCConnectionException: could not insert collection rows: [com.myCompany.jobsrc.ExecJob.subRunningIDs#1]
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:99)
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66)
at org.hibernate.persister.collection.AbstractCollectionPersister.insertRows(AbstractCollectionPersister.java:1454)
at org.hibernate.action.CollectionUpdateAction.execute(CollectionUpdateAction.java:86)
at org.hibernate.engine.ActionQueue.execute(ActionQueue.java:273)
at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:265)
at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:187)
at org.hibernate.event.def.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:321)
at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:51)
at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:1216)
at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:383)
at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:133)
at com.myCompany.jobsrc.BasicDaoImpl.saveOrUpdate(BasicDaoImpl.java:38)
at com.myCompany.jobBatch.ExecJobRoutine.generateExecJob(ExecJobRoutine.java:100)
at com.com.myCompany.jobBatch.MarkerRoutine.execute(MarkerRoutine.java:33)
at org.quartz.core.JobRunShell.run(JobRunShell.java:202)
at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:525)
Caused by: java.sql.BatchUpdateException: No operations allowed after statement closed.
at com.mysql.jdbc.PreparedStatement.executeBatchSerially(PreparedStatement.java:1269)
at com.mysql.jdbc.PreparedStatement.executeBatch(PreparedStatement.java:955)
at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.executeBatch(NewProxyPreparedStatement.java:1723)
at org.hibernate.jdbc.BatchingBatcher.doExecuteBatch(BatchingBatcher.java:70)
at org.hibernate.jdbc.BatchingBatcher.addToBatch(BatchingBatcher.java:56)
at org.hibernate.persister.collection.AbstractCollectionPersister.insertRows(AbstractCollectionPersister.java:1427)
... 14 more

Мой метод saveOrUpdate:

public void saveOrUpdate(T t){
    Session session = HibernateUtil.getSession();
    Transaction transaction = session.beginTransaction();
    session.saveOrUpdate(t);
    transaction.commit();
}

Это мой hibernate.cfg.xml:

  <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
  <property name="hibernate.connection.password">eboxroot</property>
  <property name="hibernate.connection.url">jdbc:mysql://127.0.0.1:3306  /jobtest?autoReconnect=true</property>
  <property name="hibernate.connection.username">root</property>
 <property name="hibernate.hbm2ddl.auto">update</property>
 <property name="hibernate.cache.use_second_level_cache">false</property>
  <property name="hibernate.cache.use_query_cache">false</property>
 <property name="hibernate.connection.autoReconnect">true</property>
<property    name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property> 
 <property name="c3p0.min_size">5</property>
 <property name="c3p0.max_size">30</property>
 <property name="c3p0.time_out">1800</property>
 <!--property name="c3p0.max_statement">50</property-->
<property name="c3p0.acquire_increment">5</property>
<property name="c3p0.idle_test_period">10</property>
<property name="c3p0.preferredTestQuery">select 1;</property>
<property name="c3p0.debugUnreturnedConnectionStackTraces">true</property>
<property name="hibernate.connection.autoReconnectForPools">true</property>
<!--property name="show_sql">true</property  -->

Это происходит не все время, а иногда. Может ли кто-нибудь дать мне подсказку?

Ответы [ 3 ]

2 голосов
/ 25 февраля 2012

Как вы можете видеть в своей трассировке, в верхней части написано org.hibernate.exception.JDBCConnectionException.Время от времени возможно, что ваше соединение с базой данных может быть проблемой в вашем случае.Если вы решите, что это не проблема с подключением, тогда вы должны включить флаг showSql, чтобы увидеть более подробную трассировку, чтобы выяснить, в чем именно причина.Я надеюсь, что это помогает.

0 голосов
/ 29 февраля 2012

Наконец-то решаем проблему.Это потому, что я установил для c3p0 max_statements значение 50. Он кэширует только 50. Теперь я установил значение 0, что означает отсутствие кэша.Теперь я установил его на 0, он отлично работает!Спасибо за помощь.

0 голосов
/ 28 февраля 2012
java.sql.BatchUpdateException: No operations allowed after statement closed

Возможно, вы столкнулись с проблемой из-за закрытия подключений MySQL через некоторое время.Пожалуйста, прочитайте о autoReconnect здесь .Вы должны добавить autoReconnect=true к вашему URI соединения JDBC.

...