浅谈hibernate中多表映射关系配置
更新时间:2017年06月07日 08:16:17 投稿:jingxian
下面小编就为大家带来一篇浅谈hibernate中多表映射关系配置。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
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中多表映射关系配置就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章
解决Error:(5, 28) java: 程序包org.apache.ibatis.io
这篇文章主要介绍了解决Error:(5, 28) java: 程序包org.apache.ibatis.io不存在问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-05-05基于Spring boot @Value 注解注入属性值的操作方法
这篇文章主要介绍了结合SpEL使用@Value-基于配置文件或非配置的文件的值注入-Spring Boot的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-07-07
最新评论