hibernate 一对多_Spring Data JPA(8)多表操作之:一对多操作

多表操作

一对多操作

客户和联系人的关系,一个客户可以对应多个联系人,一个联系人只能对应一个客户

配置一对多和多对一关系并配置外键

@OneToMany : 配置一对多关系

targetEntity :对方对象的字节码对象

mappedBy:对方配置关系的属性名称,这样主表就放弃外键维护权

cascade : 配置级联(可以配置到设置多表的映射关系的注解上),取值有:

CascadeType.ALL: 所有

CascadeType.MERGE:更新

CascadeType.PERSIST:保存

CascadeType.REMOVE:删除

fetch : 配置关联对象的加载方式,取值有:

EAGER :立即加载

LAZY :延迟加载

@JoinColumn : 配置外键

name:外键字段名称

referencedColumnName:参照的主表的主键字段名称

@ManyToOne : 配置多对一关系

targetEntity:对方的实体类字节码

在配置文件的entityManagerFactory的bean中注入jpa的配置信息

<!--

在客户实体类中配置联系人集合

@OneToMany

在客户实体类上(一的一方)添加了外键了配置,所以对于客户而言,也具备了维护外键的作用

在联系人实体类中添加客户对象

@ManyToOne

外键配置到了多的一方,就会在多的一方维护外键

测试一下保存操作

@RunWith

这时可以看到自动重建了表并插入了数据

c4aa7db9ec7d970841b6da80b24b3952.png

但是数据库中的外键列为空

28c384a44668734c59b2f794206f4f3b.png

这里实体类中没有配置关系,在测试中并没有把customer和linkMan这两个对象关联起来,因此外键列显示为空,因此需要在save方法之前添加:

customer.getLinkMans().add(linkMan);

这个测试是在客户(一的一方)进行维护外键

c6aaec25140bc761e4f315a67bbd2de3.png

这样就在从表中有了外键信息

ae60635edfdfc5515e494c2786a6cdd4.png

我们也可以在联系人中(多的一方)维护外键

linkMan.setCustomer(customer);

这样就不会像在客户中维护外键多一句update语句

3df49017fdf28476668507cc0126fbf1.png

也可以达到同样的效果

120fb9b3927d4a5b476ca7f74da97e43.png

两个同时维护外键也可以

linkMan

但是由于一的一方可以维护外键,会发送update语句,如果我们不希望多余的update去维护外键,可以在一的一方放弃维护权。

在客户实体类中只声明一对多关系即可在一的一方放弃外键的维护权

@OneToMany

这样一对多中一的一方就没有了外键的维护权,就没有了多余的update语句

4ad5422090cc6c89ada13a7bcc043f8a.png

级联添加和删除

在OneToMany注解中可以添加级联cascade

@OneToMany

ALL就是增删改操作都可以级联

测试保存一个客户的同时,保存客户的所有联系人

@Test

63c7e0a6499513029b0d75e8b574fe1b.png

测试级联删除:删除1号客户的同时,删除1号客户的所有联系人

@Test
    

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值