hibernate jpa 配置model,一对多的关系,保存主表时级联保存子表,子表中的主表外键为空。难道要先保存主表,然后手动去赋子表的外键?这还叫级联保存吗。求解!!!
例如:
[code="java"]
public class Order extends AbstractNsSimpleModel {
private static final long serialVersionUID = -3227571634593243399L;
@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "order", orphanRemoval = true)
private Set<OrderItem> orderItems = new HashSet<OrderItem>();
public Set<OrderItem> getOrderItems() {
return orderItems;
}
public void setOrderItems(Set<OrderItem> orderItems) {
this.orderItems = orderItems;
}
}
[/code]
[code="java"]
public class OrderItem extends AbstractNsSimpleModel {
private static final long serialVersionUID = -7120458190166247286L;
@Column(name = "ORDER_ID", insertable = false, updatable = false, nullable = false)
private Long orderId;
@ManyToOne(fetch = FetchType.EAGER, optional = false)
@JoinColumn(name = "ORDER_ID", referencedColumnName = "ID")
private Order order;
public Long getOrderId() {
return orderId;
}
public void setOrderId(Long orderId) {
this.orderId = orderId;
}
public Order getOrder() {
return order;
}
public void setOrder(Order order) {
this.order = order;
}
}
[/code]
保存order时,级联保存orderItem,orderItem是被保存了,但是外键orderId为null。
你用了双向关联了, 多的一方是关系维护端, 如果你想直接保存order 级联保存, 需要在orderItem.setOrder(order), 这样多的一方才有外键插入数据了。 建议写成专家模式, 在Order类中添加一个方法, 添加orderItem的操作。
public void addOrderItem(OrderItem item) {
if(!orderItems.contains(item)) {
item.setOrder(this);
this.orderItems.add(item)
}
}
需要重写hasCoder 跟equals 方法。
order.getOrderItems().add(orderItem)之后别忘了orderItem.setOrder(order)
我猜你用的是mysql,
举个例子:
有A、B两张表,A表中一条数据对应B表多条数据,换句话说,就是A表的主键是B表的外键,这种情况如果保存的时候,需要先保存A,A会生成一个主键,然后获取A的主键传值给B每条数据,然后保存即可