Hibernate一对多关联双向映射

今天在刚公司改bug,有个一对多的映射文件写错了。自己对一对多的关联有点生疏了,把改好的代码贴出来,加深印象。

有两个实体,分别是Shop和Product。Shop是一的一端,Product是多的一端,Shop里有多个Product。

 

Shop.java
 private Set <Product>productid = new HashSet<Product>();//商店中的商品

Shop.hbm.xml
<set name="productid" inverse="false" cascade="save-update">
        <key column="shop" />
        <one-to-many class="pojo.Product"/>
        </set>

 


Product.java
private Shop shopid; //商品所在的商店,指向商店


Product.hbm.xml
 <many-to-one name="shopid" column="shop" cascade="save-update" class="pojo.Shop"/>

 

两个映射文件中有个关键点,就是key 里的column 属性应该和many-to-one 里的column 属性完全一致(加粗的地方)。这样多对一才关联上了。

 

如果在一一端维护一对多关系,hibernate会发出多余的update语句,所以我们一般在多的一端来维护关联关系。

关于inverse属性:
   inverse主要用在一对多和多对多双向关联上,inverse可以被设置到集合标签<set>上,默认inverse为false
   所以我们可以从一一端和多一端维护关联关系,如果蛇者成inverse为true,则我们只能从多一端来维护
   关联关系   
  
   注意:inverse属性,只影响数据的存储,也就是持久化
   试验:如果不在一的一端设置inverse的属性为true,当更新一的一端时,多的一端和更新的一一端对象关联 的数据关联会丢失,如果设置了此属性为true,则不会发生此中情况
      即:一一端设置inverse=false,执行更新时发出的sql语句如下:
        Hibernate: update t_group set name=? where id=?
        Hibernate: update t_user set groupid=null where groupid=?
        一一端设置inverse=true,执行更新时发出的sql语句如下:
        Hibernate: update t_group set name=? where id=?
  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值