一是业务场景需要,很多情况下都需要双向查询。
另外一方面,双向关联不用额外表,效率更高。
OneToOne双向关联父端设置FetchType.LAZY有效么
无效,因为@OneToOne自带unique约束(子端才会有unique约束)。父端并不知道子端是否重复,所以会去查所有子元素。
这涉及到了n+1的问题(感觉1+n更妥当)

那么OneToOne就一定不能懒加载么,不是的,可以通过​​@LazyToOne( LazyToOneOption.NO_PROXY )​​ 来实现,代码:

@OneToOne(
mappedBy = "phone",
cascade = CascadeType.ALL,
orphanRemoval = true,
fetch = FetchType.LAZY
)
@LazyToOne( LazyToOneOption.NO_PROXY )
private PhoneDetails details;

关于unique报错的代码(persist子端会报错,persist父端不会报错):

Phone phone = new Phone( "123-456-7890" );
PhoneDetails details = new PhoneDetails( "T-Mobile", "GSM" );
PhoneDetails details2 = new PhoneDetails( "T-Mobile", "GSM2" );
details.setPhone(phone);
details2.setPhone(phone);

entityManager.persist( details2 );
entityManager.flush();