1.one-to-many 一对多关系的映射配置(在一的一方实体映射文件中配置)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<!--
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 多对一关系映射配置(在多的一方实体映射文件中配置)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<!--
cascade属性:级联操作属性
save-update: 级联保存,保存客户时,级联保存客户关联的联系人
delete:级联删除,删除客户时,级联删除客户关联的联系人
all:级联保存+级联删除
-->
<!--
没有inverse属性:
外键列所在实体,无法放弃维护关联关系.
-->
<!-- 多对一 -->
<many-to-one name= "customer"
column= "lkm_cust_id"
class = "Customer" ></many-to-one>
|
3.many-to-many 多对多关系映射配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
<!-- 多对多关系配置
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中多表映射关系配置就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。