浅谈hibernate中多表映射关系配置

发布时间:2020-09-05 13:11:32 作者:jingxian
来源:脚本之家 阅读:141

1.one-to-many 一对多关系的映射配置(在一的一方实体映射文件中配置)

<!-- 
   cascade属性:级联操作属性
    save-update: 级联保存,保存客户时,级联保存客户关联的联系人
    delete:级联删除,删除客户时,级联删除客户关联的联系人
    all:级联保存+级联删除
   -->
   <!-- 
   inverse属性:设置是否不维护关联关系
    true:不维护关联
    false(默认值):维护关联
   -->
  <!-- 一对多 -->
  <set name="linkMen" inverse="true" >
   <!-- 外键列名 -->
   <key column="lkm_cust_id" ></key>
   <!-- 该集合是一对多关系表达,关联的对象时linkman -->
   <one-to-many class="LinkMan" />
  </set>

一对多|多对一关系中,放置sql语句冗余.一般选择一的一方放弃维护,inverse属性设置为true.

2.many-to-one 多对一关系映射配置(在多的一方实体映射文件中配置)

<!-- 
   cascade属性:级联操作属性
    save-update: 级联保存,保存客户时,级联保存客户关联的联系人
    delete:级联删除,删除客户时,级联删除客户关联的联系人
    all:级联保存+级联删除
   -->
   <!-- 
    没有inverse属性:
     外键列所在实体,无法放弃维护关联关系.
   -->
  <!-- 多对一 -->
  <many-to-one name="customer" 
   column="lkm_cust_id" 
   class="Customer" ></many-to-one>

3.many-to-many 多对多关系映射配置

<!-- 多对多关系配置 
    table:中间表表名
  -->
   <!-- 
   inverse属性:设置是否不维护关联关系
    true:不维护关联
    false(默认值):维护关联
   -->
   <!-- 
   cascade属性:级联操作属性
    save-update: 级联保存,保存客户时,级联保存客户关联的联系人
    delete:级联删除,删除客户时,级联删除客户关联的联系人
    all: 级联保存+级联删除
   -->
  <set name="roles" table="sys_user_role" >
   <!-- 别人引用"我"的外键列名 -->
   <key column="user_id" ></key>
   <!-- 表达集合是多对多关系
    class属性:表达我与谁是多对多
    column属性:表达另外一个外键列名
    -->
   <many-to-many class="Role" column="role_id" ></many-to-many>
  </set>

多对多关系中,选择一方发起维护关系,放置中间表数据录入重复,根据业务逻辑决定,如商品和订单是多对多关系,订单维护商品放弃维护。

以上这篇浅谈hibernate中多表映射关系配置就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持亿速云。

推荐阅读:
  1. Hibernate如何配置
  2. hibernate 一对多 多对一映射关系

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

hibernate 多表 映射关系

上一篇:MySQL服务正在启动或停止中,请稍候片刻后再试一次【解决方案】

下一篇:java设计模式笔记之装饰模式

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》