springDataJpa一对多和多对一

一.一对多和多对一的关系映射

1.逻辑

先建立好表之间的关系。

通过外键将主表的id进行绑定。

2.双向关联和单向关联

双向关联:指的是俩表之间可以互相关联,操作一张表的同时可以操作另一张表。

单向关联:指的是只有一张表可以关联另一张表,另一张表不能操作该表。

3.一对多的关系映射

(1)语法

//配置联系人的关联,注意toString不能包含该属性
/**
 * 配置一对多关系
 *      1.关系声明
 *          targetEntity = 对方实体类的字节码对象
 *      2.配置外键
 *          @JoinColumn(name = "从表的外键字段名称",referencedColumnName = "主表的id")
 */
@OneToMany(targetEntity = 对方实体类的字节码对象)
@JoinColumn(name = "lkm_cust_id",referencedColumnName = "cust_id")

(2)范例

图片

图片

4.多对一的关系映射

(1)语法

/**
 * 配置多对一的关系
 *      1.配置表关系
 *          @ManyToOne(targetEntity = 一的一方实体类字节码对象)
 *      2.配置外键
 *          @JoinColumn(name = "从表的外键字段名称",referencedColumnName = "主表的id")
 */
@ManyToOne(targetEntity = Customer.class)
@JoinColumn(name = "lkm_cust_id",referencedColumnName = "cust_id")

(2)范例

图片

图片

5.设置消除主表的外键维护全

(1)语法

//放弃外键约束权,mappedBy设置外键约束维护是从表的customer属性上
@OneToMany(mappedBy = "customer")   //mappedBy设置外键约束所在位置

(2)范例

图片

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-M4eQm12C-1590222877026)(https://uploader.shimo.im/f/pLaR4ufxy7YU8zYe.png!thumbnail)]

6.使用外键约束同时操作俩张表

图片

图片

图片

二.设置级联操作

1.概述

操作一个对象同时操作他的关联对象。

2.逻辑

  1. 需要区分操作的主体。
  2. 需要操作主体的实现类上,添加级联属性(需要添加到多表映射关系的注解上)
  3. cascade(配置级联)

3.级联添加的语法

//不推荐级联删除,如果一对多或者多对一,可以使用。多对多不推荐级联删除
//cascade设置级联属性,删除的属性值是delete
cascade = {CascadeType.MERGE,CascadeType.PERSIST,CascadeType.REMOVE}

4.范例

图片

三.源码

day03.rar

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值