我在映射包含列表(或映射)的实体时遇到问题。我尝试了各种注释组合,但是“最佳”的两种变体都有这种行为。例如,如果父对象具有3个子对象,则会检索父对象三次。
在我的情况下,我有一个UserOrder
对象,其中包含带有计数的Product
对。数据结构看起来像这样
@Entity
public class UserOrder{
/*
* VARIATION 1
* I did actually vary some of these annotions, not all are necessary.
* I believe the @CollectionTable is the key here
*/
@ElementCollection(fetch = FetchType.EAGER)
@CollectionTable
@Column
@Embedded
private List<ProductCount> products;
/*
* VARIATION 2
*/
@ElementCollection(fetch = FetchType.EAGER)
private Map<Product, Integer> products = new HashMap<Product, Integer>();
// get/set
// ...
}
@Embeddable
/* Only used in variation 1 */
public class ProductCount{
@OneToOne
private Product product;
@Column
private Integer amount;
// get/set
}
@Entity
public class Product
{
// ...
}
然后使用类似的东西调用并显示(这是针对变体2)
<!-- Called via DAO/Service layers
List<Order> orders = getSession().createCriteria(UserOrder.class).list();
-->
<c:forEach items="${orders}" var="order">
<fmt:formatDate value="${order.time}" type="both" />
<c:forEach items="${order.products}" var="pc">
${pc.value} x ${pc.key.name}
</c:forEach>
</c:forEach>
为了记录,我使用Spring(3.1),Hibernate(3.5),我想继续使用JPA注释。
当我检索订单时,我会为其包含的每个产品获取一个UserOrder
- 对象,而不是我存储的每个订单都有一个UserOrder
。所以我在列表中得到了重复项,所有这些都包含了它所包含的产品的完整信息。没有产品的订单也包括在内
如何让Hibernate给我一个(1)UserOrder
而不是每个产品一个?或者,我是否采用正确的方法对此结构进行建模?
答案 0 :(得分:0)
选项: