Я пишу простой проект, бизнес-приложение, написанное на Swing, использующее Hibernate для бэк-энда. Я пришел из Spring, который дал мне простые способы использования гибернации и транзакций. В любом случае мне удалось заставить Hibernate работать. Вчера при написании кода для удаления компонента из БД я получил следующее:
org.hibernate.HibernateException: Illegal attempt to associate a collection with two open sessions
Код удаления просто:
Session sess = HibernateUtil.getSession();
Transaction tx = sess.beginTransaction();
try {
tx.begin();
sess.delete(ims);
} catch (Exception e) {
tx.rollback();
throw e;
}
tx.commit();
sess.flush();
и мой HibernateUtil.getSession()
:
public static Session getSession() throws HibernateException {
Session sess = null;
try {
sess = sessionFactory.getCurrentSession();
} catch (org.hibernate.HibernateException he) {
sess = sessionFactory.openSession();
}
return sess;
}
дополнительные сведения: я никогда не закрываю сеанс гибернации в своем коде, только при закрытии приложения. Это неправильно? Почему я получаю это при удалении (только для этого компонента, другие работают), а у меня нет при других операциях (вставка, запрос, обновление)?
Я перечитал и попытался изменить мой getSession
метод просто в sessionFactory.getCurrentSessionCall()
, но я получил: org.hibernate.HibernateException: No CurrentSessionContext configured!
Hibernat conf:
<hibernate-configuration>
<session-factory >
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost/joptel</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">******</property>
<property name="hibernate.connection.pool_size">1</property>
<property name="show_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
..mappings..
</session-factory>
</hibernate-configuration>