hibernate 级联保存明细时,外键没有被赋值

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每条数据,然后保存即可