У меня проблема с удалением с помощью hibernate. Когда я пытаюсь удалить, я получаю исключение о том, что дети существуют, и есть нарушение FK. Я хочу удалить также и детей, но удаление не выглядит каскадным. Примерно через неделю после попытки решить эту проблему я прочитал, что должен использовать HibernateInterceptor, чтобы сеанс оставался открытым, чтобы можно было загружать дочерние элементы. Когда я пытаюсь сделать это сейчас, я получаю следующую ошибку:
Failed to load portlet com.blah.blah.CommunicationsPortlet: java.lang.ClassCastException: $Proxy27 incompatible with com.blah.blah.HibernateCommunicationsDAOImpl
Вот выдержка из моего файла сопоставления:
<set name="communicationCountries" inverse="true" cascade="all,delete-orphan">
<key column="COM_ID" not-null="true" on-delete="cascade" />
<one-to-many class="com.blah.blah.CommunicationCountry"/>
</set>
Вот выдержка из контекста приложения:
<bean id="hibernateCommunicationsDAOImplTarget"
class="com.blah.blah.dao.impl.HibernateCommunicationsDAOImpl">
<property name="sessionFactory">
<ref bean="sessionFactory"/>
</property>
</bean>
<bean id="hibernateCommunicationsDAOImpl" class="org.springframework.aop.framework.ProxyFactoryBean">
<property name="target"><ref bean="hibernateCommunicationsDAOImplTarget"/></property>
<property name="proxyInterfaces">
<value>com.blah.blah.dao.CommunicationsDAO</value>
</property>
<property name="interceptorNames">
<list>
<value>hibernateInterceptor</value>
</list>
</property>
</bean>
Вот метод в моем DAO:
public void deleteCommunication(Integer id) throws DataAccessException
{
HibernateTemplate hibernate = getHibernateTemplate();
Communication existing = (Communication)hibernate.get(Communication.class, id);
hibernate.initialize( existing.getCommunicationCountries());
hibernate.delete(existing);
}
Я действительно не знаю, что я делаю неправильно. У меня нет очень сложной схемы, только одна таблица, которая приводит к детям (странам). Любые идеи, что я мог бы сделать, чтобы это исправить?