【发布时间】:2010-12-31 23:48:36
【问题描述】:
我有一个 Order 类,它有一个 OrderTransactions 列表,我使用一对多 Hibernate 映射来映射它,如下所示:
@OneToMany(targetEntity = OrderTransaction.class, cascade = CascadeType.ALL)
public List<OrderTransaction> getOrderTransactions() {
return orderTransactions;
}
这些Orders 也有一个字段orderStatus,用于使用以下条件进行过滤:
public List<Order> getOrderForProduct(OrderFilter orderFilter) {
Criteria criteria = getHibernateSession()
.createCriteria(Order.class)
.add(Restrictions.in("orderStatus", orderFilter.getStatusesToShow()));
return criteria.list();
}
这行得通,结果符合预期。
现在这是我的问题:为什么当我将获取类型明确设置为EAGER 时,Orders 会在结果列表中出现多次?
@OneToMany(targetEntity = OrderTransaction.class, fetch = FetchType.EAGER, cascade = CascadeType.ALL)
public List<OrderTransaction> getOrderTransactions() {
return orderTransactions;
}
我必须如何更改我的条件代码才能在新设置下达到相同的结果?
【问题讨论】:
-
您是否尝试过启用 show_sql 以查看下面发生了什么?
-
请同时添加 OrderTransaction 和 Order 类代码。\