hibernate级联删除

一对多的双向关联:user对应多个order

user.xml:

<class name="com.examp.ShoppingOnline.User"
            table="user"
            discriminator-value="C">            
           <id name="id">
             <generator class="increment"/>
        </id>
        <property name="username"/>
        <property name="password"/>
        <property name="realname"/>
        <property name="tel"/>
        <property name="address"/>
        <property name="zip"/>
        <property name="email"/>
        <set name="orders" table="orders" cascade="all" inverse="true">
            <key column="user_id"/>
            <one-to-many class="Order"/>
        </set>
    </class>

 

order.xml:

<class name="com.examp.ShoppingOnline.Order"
            table="orders"
            discriminator-value="C">      
        <id name="id">
               <generator class="increment"/>
        </id>
        <property name="orderno"/>
           <property name="realname"/>
        <property name="address"/>
        <property name="zip"/>
        <property name="tel"/>
        <property name="payment"/>
        <property name="email"/>
        <property name="memo"/>
        <property name="price"/>
        <property name="time"/>
        <property name="tag"/>
        <many-to-one name="user" class="User" column="user_id" cascade="all"/>
     </class>

注意如果一的那方不加inverse="true",增,更可以正常,但删除会引起错误。

Hibernate中的inverse在表关系映射中经常应用,
  inverse的值有两种,“true”和“false”。inverse="false"是默认的值,如果设置为true 则表示对象的状态变化不会同步到数据库 ;设置成false则相反;
  inverse的作用:在hibernate中是通过inverse的设置来决定是有谁来维护表和表之间的关系的。
  我们说inverse设立不当会导致性能低下,其实是说inverse设立不当,会产生多余重复的SQL语句甚至致使JDBC exception的throw。这是我们在建立实体类关系时必须需要关注的地方。一般来说,inverse=true是推荐使用,双向关联中双方都设置 inverse=false的话,必会导致双方都重复更新同一个关系。但是如果双方都设立inverse=true的话,双方都不维护关系的更新,这也是 不行的,好在一对多中的一端:many-to-one默认是inverse=false,避免了这种错误的产生。但是多对多就没有这个默认设置了,所以很 多人经常在多对多的两端都使用inverse=true,结果导致连接表的数据根本没有记录,就是因为他们双分都没有责任维护关系。所以说,双向关联中最 好的设置是一端为inverse=true,一端为inverse=false。一般inverse=false会放在多的一端,那么有人提问了, many-to-many两边都是多的,inverse到底放在哪儿?其实hibernate建立多对多关系也是将他们分离成两个一对多关系,中间连接一 个连接表。所以通用存在一对多的关系,也可以这样说:一对多是多对多的基本组成部分。

  cascade定义的是关系两端对象到对象的级联关系;而inverse定义的是关系和对象的级联关系。
  inverse只对set+one-to-many(或many-to-many)有效,对many-to-one, one-to-one无效。cascade对关系标记都有效。
  inverse对集合对象整体起作用,cascade对集合对象中的一个一个元素起作用,如果集合为空,那么cascade不会引发关联操作。

  

所以要是在User.hbm.xml没设置inverse的话,它默认的是false,那么它就会把级联关系刷新,因为user_id是在

order表中设置,所以会出现user_id=null,所以会报错。

当在User.hbm.xml设置 inverse="true",它就不会再去更新级联关系,就可以直接进入数据库层面操作数据,所以上面删除用户时同时也把有级联关系的文章删掉了。

 

posted on 2014-08-28 16:39  颓废的悠然  阅读(233)  评论(0编辑  收藏  举报

导航