@ManyToOne和@OneToMany

本文详细解析了Hibernate中ManyToOne和OneToMany的关系模式,重点讨论了它们的区别、如何避免中间表的产生、外键管理和懒加载策略。特别强调了mappedBy属性的作用以及fetch和NotFound注解对加载行为的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. ManyToOne:多对一、单向,不产生中间表,但可以用@JoinColumn(name=" ")来指定生成外键的名字,外键在多的一方表中产生。
  2. OneToMany:一对多、单向,会产生中间表,此时可以用@OneToMany@JoinColumn(name=" ") 避免产生中间表,并且指定了外键的名字,同样,外键在多的表中存在着。
  3. OneToMany+ManyToOne双向(一起用)。如果不在@OneToMany中加mappedy属性就会产生中间表,此时,通常在@ManyToOne的注解下再填上注解@Joincolumn(name=" ") 来指定外键的名字(多的一方为关系维护端,关系维护端负责外键记录的更新,关系被维护端没有权利更新外键记录)

@OneToMany(mappedBy=“一对多中,多中一的属性”) 出现mappedBy为被维护端,默认为延迟加载。

例子:

@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="child_id")
private OrderChild orderChild;


@OneToMany(mappedBy="orderChild",fetch= FetchType.LAZY,cascade={CascadeType.MERGE})
@NotFound(action=NotFoundAction.IGNORE)//代表可以为空
private List<OrderChildGoods> goodsList;

hibernate中@ManyToOne默认是立即加载,@OneToMany默认是懒加载。
但是如果加上了@NotFound之后,设置的fetch=FetchType.LAZY是不起作用的,也就是设置@NotFound后变为了立即加载。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酱子姐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值