我的问题对我来说似乎很简单,但我似乎无法找到有效的答案。我有一个休眠实体,它与另一个实体具有多对多关联,默认情况下会延迟获取。我想创建一个标准,它将返回带有急切加载的 ManyToMany 关联的实体。
这是有问题的实体(删除了不相关的部分):
@Entity
public class Order {
@ManyToMany
private List<Item> items;
@ManyToMany
private List<Discount> discountEntries;
...
}
以下是我迄今为止的显着尝试和结果:
Criteria criteria = getSession().createCriteria(Order.class)
.setFetchMode("items", FetchMode.SELECT)
.setFetchMode("discountEntries", FetchMode.SELECT);
criteria.list();
- 懒惰地加载项目
Criteria criteria = getSession().createCriteria(Order.class)
.setFetchMode("items", FetchMode.JOIN)
.setFetchMode("discountEntries", FetchMode.JOIN);
criteria.list();
- 无法提取多个行李
Criteria criteria = getSession().createCriteria(Order.class)
.createAlias("items", "items", CriteriaSpecification.INNER_JOIN)
.setFetchMode("items", FetchMode.JOIN)
.createAlias("discountEntries", "discountEntries", CriteriaSpecification.INNER_JOIN)
.setFetchMode("discountEntries", FetchMode.JOIN);
criteria.list();
- 返回一个空列表
编辑:添加了另一个多对多关联,因为这似乎是问题的一部分。