Hibernate 一对多关系,从一的一方添加多。
User表:@OneToMany(mappedBy="user",targetEntity=Order.class,cascade=CascadeType.ALL)@Jo...
User表:
@OneToMany(mappedBy="user",targetEntity=Order.class,cascade=CascadeType.ALL)
@JoinColumn(name="userid")
private List<Order> orders;
Order表:
@ManyToOne(targetEntity=User.class,cascade=CascadeType.ALL)
@JoinColumn(name="userid")
private User user;
我在做下面这步操作:
User user = ite.next();
List<Order> orders = user.getOrders();
orders.add(new Order("RECEIVED", 1, new Timestamp(new Date().getTime()), "aa", 1));
session.update(user);
结果是:新的order是存进去了,但是在Order表中的userid段(也就是外键段),却是null,为什么,它不应该自动填入user的id么? 展开
@OneToMany(mappedBy="user",targetEntity=Order.class,cascade=CascadeType.ALL)
@JoinColumn(name="userid")
private List<Order> orders;
Order表:
@ManyToOne(targetEntity=User.class,cascade=CascadeType.ALL)
@JoinColumn(name="userid")
private User user;
我在做下面这步操作:
User user = ite.next();
List<Order> orders = user.getOrders();
orders.add(new Order("RECEIVED", 1, new Timestamp(new Date().getTime()), "aa", 1));
session.update(user);
结果是:新的order是存进去了,但是在Order表中的userid段(也就是外键段),却是null,为什么,它不应该自动填入user的id么? 展开
展开全部
这么改:
User表:
@OneToMany(mappedBy="user")
@Fetch(FetchMode.SUBSELECT)
private List<Order> orders;
Order表:
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name="userid")
private User user;
@JoinColumn只需要写在多的一端就行了
User表:
@OneToMany(mappedBy="user")
@Fetch(FetchMode.SUBSELECT)
private List<Order> orders;
Order表:
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name="userid")
private User user;
@JoinColumn只需要写在多的一端就行了
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询