dqm102308
2014-03-26 15:26
浏览 1.0k
已采纳

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。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

4条回答 默认 最新

  • coderliang2018 2014-03-27 10:35
    已采纳

    你用了双向关联了, 多的一方是关系维护端, 如果你想直接保存order 级联保存, 需要在orderItem.setOrder(order), 这样多的一方才有外键插入数据了。 建议写成专家模式, 在Order类中添加一个方法, 添加orderItem的操作。

    public void addOrderItem(OrderItem item) {
    if(!orderItems.contains(item)) {
    item.setOrder(this);
    this.orderItems.add(item)
    }
    }

    需要重写hasCoder 跟equals 方法。

    点赞 评论
  • 0x07c00 2014-03-26 16:29

    order.getOrderItems().add(orderItem)之后别忘了orderItem.setOrder(order)

    点赞 评论
  • thunder110 2014-03-26 20:02

    举个例子:
    有A、B两张表,A表中一条数据对应B表多条数据,换句话说,就是A表的主键是B表的外键,这种情况如果保存的时候,需要先保存A,A会生成一个主键,然后获取A的主键传值给B每条数据,然后保存即可

    点赞 评论
  • bewithme 2014-03-26 22:43

    我猜你用的是mysql,

    点赞 评论

相关推荐 更多相似问题