用法和单向一对多和单向多对一用法是一样的,需要说的就是让那一边来维护关联关系,如果不考虑这个也没什么关系,考虑的话可以对性能有一点提升。
//这里的mappedBy是指定由Order的customemr属性维护关联关系
//注意! 在使用mappedBy属性时,不能同时使用@JoinColumn注解,只需要在维护关联关系的一端配置@JoinColumn注解即可
//@JoinColumn(name = "CUSTOMER_ID")
@OneToMany(cascade={CascadeType.REMOVE},mappedBy="customer")
public Set<Order> getOrders() {
return orders;
}
下面说一下为什么会对性能有提升
默认两边维护关联关系:
若先保存N的一端,再保存1的一端,则两边在发送insert语句之后都会额外发送update去维护关联关系,N的一端时为了更新外键值
若先保存1的一端,则只有1的一端会发送update语句
配置只有多的一边维护关联关系:
这里只说先保存1的一端的情况:我们配置了由N的一端维护关联关系,我们在保存的时候先保存1的一端,首先1的一端不会再发送update语句,因为它已经不需要维护关联关系。其次因为先保存了1的一端,所以在保存N的一端时已经知道1的主键值,所以也不需要发送update语句。