hibernate 级联删除

配置文件和pojo类如下:

 

Xml代码 
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
  3. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
  4. <!--  
  5.     Mapping file autogenerated by MyEclipse Persistence Tools 
  6. -->  
  7. <hibernate-mapping>  
  8.     <class name="com.hotel.dao.Movietype" table="movietype" catalog="hotelfidelio">  
  9.         <id name="id" type="java.lang.Integer">  
  10.             <column name="id" />  
  11.             <generator class="native"></generator>  
  12.         </id>  
  13.         <property name="name" type="java.lang.String">  
  14.             <column name="name" length="60" not-null="true" />  
  15.         </property>  
  16.         <property name="field1" type="java.lang.String">  
  17.             <column name="field1" length="20" />  
  18.         </property>  
  19.         <set name="movies"   
  20.           table="movie"  
  21.           inverse="true"  
  22.           lazy="false"  
  23.           cascade="all">  
  24.          <key column="id_movietype"></key>  
  25.          <one-to-many class="com.hotel.dao.Movie"/>  
  26.         </set>  
  27.     </class>  
  28. </hibernate-mapping>  

 

 

 

 

 

Xml代码 
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
  3. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
  4. <!--  
  5.     Mapping file autogenerated by MyEclipse Persistence Tools 
  6. -->  
  7. <hibernate-mapping>  
  8.     <class name="com.hotel.dao.Movie" table="movie" catalog="hotelfidelio">  
  9.         <id name="id" type="java.lang.Integer">  
  10.             <column name="id" />  
  11.             <generator class="native"></generator>  
  12.         </id>  
  13.         <property name="moviename" type="java.lang.String">  
  14.             <column name="moviename" length="200" not-null="true" />  
  15.         </property>  
  16.         <property name="movienameSys" type="java.lang.String">  
  17.             <column name="moviename_sys" length="300" not-null="true" unique="true" />  
  18.         </property>  
  19.         <property name="director" type="java.lang.String">  
  20.             <column name="director" length="200" />  
  21.         </property>  
  22.         <property name="impersonator" type="java.lang.String">  
  23.             <column name="impersonator" length="200" />  
  24.         </property>  
  25.         <property name="charge" type="java.lang.Double">  
  26.             <column name="charge" precision="22" scale="0" not-null="true" />  
  27.         </property>  
  28.         <property name="intro" type="java.lang.String">  
  29.             <column name="intro" length="16277215" />  
  30.         </property>  
  31.         <property name="imgsrc" type="java.lang.String">  
  32.             <column name="imgsrc" length="300" />  
  33.         </property>  
  34.         <property name="field1" type="java.lang.String">  
  35.             <column name="field1" length="20" />  
  36.         </property>  
  37.         <property name="field2" type="java.lang.String">  
  38.             <column name="field2" length="20" />  
  39.         </property>  
  40.     <property name="idmovietype" type="java.lang.Integer">  
  41.         <column name="id_movietype" precision="3" scale="0" not-null="true" />  
  42.     </property>  
  43.     <many-to-one   
  44.          name="movietype"  
  45.          class="com.hotel.dao.Movietype"  
  46.          column="id_movietype"  
  47.          insert="false"  
  48.          update="false"  
  49.              outer-join="auto"  
  50.          fetch="select"  
  51.              access="property"  
  52.              not-null="true"  
  53.              lazy="false"  
  54.          >  
  55.     </many-to-one>  
  56.     </class>  
  57. </hibernate-mapping>  

 

 

网上很多帖子都说cascade="all" 就可以级联删除,但是我这里怎么设置都没法成功,观察输出日志

只有  movietype的删除 sql:

 

Hibernate: delete from hotel.movietype where id=? 

 

之后看到 arthur.3726 文章:http://arthur-3726.javaeye.com/blog/422877 发现只有用hibernate自带的事物执行语句才能执行级联删除,觉得有可能不是配置文件的问题,而是java代码的问题:

 

Eclipse配置完ssh后,自动生成的代码:

 

 

Java代码 
  1. public void delete(Movietype persistentInstance) {  
  2.     log.debug("deleting Movietype instance");  
  3.     try {  
  4.         getHibernateTemplate().delete(persistentInstance);  
  5.         log.debug("delete successful");  
  6.     } catch (RuntimeException re) {  
  7.         log.error("delete failed", re);  
  8.         throw re;  
  9.     }  
  10. }  

 

 

改成直接由hibernate的session来执行:

 

 

Java代码 
  1. public void delete_cascade(final Movietype persistentInstance) {  
  2.     log.debug("deleting Movietype instance");  
  3.     try {  
  4.         getHibernateTemplate().executeFind(new HibernateCallback() {  
  5.             public Object doInHibernate(Session s)  
  6.                     throws HibernateException, SQLException {  
  7.                 s.setFlushMode(FlushMode.AUTO);  
  8.                 s.beginTransaction().begin();  
  9.                 s.delete(persistentInstance);  
  10.                 s.beginTransaction().commit();  
  11.                 s.close();  
  12.                 return null;  
  13.             }  
  14.         });  
  15.     } catch (RuntimeException re) {  
  16.         log.error("find all failed", re);  
  17.         throw re;  
  18.     }  
  19. }  

 

 测试删除movietype,输出sql语句:

 

Hibernate: delete from hotelfidelio.movie where id=?

Hibernate: delete from hotelfidelio.movietype where id=?

 

删除成功。

 

参考:http://arthur-3726.javaeye.com/blog/422877

         http://docs.jboss.org/hibernate/stable/core/reference/en/html_single/#objectstate-transitive

         http://docs.jboss.org/hibernate/stable/core/reference/en/html/objectstate.html#objectstate-transitive

         http://docs.jboss.org/hibernate/stable/core/reference/en/html/example-parentchild.html

posted on 2010-07-29 09:55  小顾问  阅读(7079)  评论(0编辑  收藏  举报