0

我试图让问题更小,但我无法让它更小:(

我有 2 个实体,这就是它们的关联方式:

Collection (1) ----> (n) Item
Item (0 or 1) -----> (n) Item

即每个Item都与一个有关Collection。此外,每个都Item可以有 0 个或多个孩子Item。如果有一个孩子Item,孩子Item将有一个非空parent_item_id

表:

收藏品

collection_id raw

项目

item_id raw
collection_id raw
parent_item_id raw

映射:

class Collections
{
   @Id @Column("collection_id")
   String id;

   @OneToMany(fetch=FetchType.EAGER, cascadeType.ALL, mappedBy="collection")
   List<Items> items;
}

class Items
{
  @Id @Column("item_id")
  String id;

  @ManyToOne(optional=false)
  @JoinColumn(name="collection_id")
  Collections collection;

  @ManyToOne(optional=true)
  @JoinColumn(name="parent_item_id")
  Items parentItem;
}

假设我创建了一个像这样的对象:

//Constructor parameters are the Ids.
Collections collection1 = new Collections("1234");
Items i1 = new Items("111");
Items i2 = new Items("222");
item1.parentItem = item2;
item1.collection = collection1;
item2.collection = collection1;
List<Items> listItems = new ArrayList<Items>(1);
listItems.add(item2);
collection1.items = listItems;

我们有一个数据访问层 (DA),它是 JPA 和 Hibernate 的包装器。接下来,我执行两个操作:

Collections collection1 = DA.merge(collection1);
Collections collection2 = DA.find(collection1.id);

我希望collection2.items.size()返回 2。但它返回 1。(PS:实际上有 2 项与 collection1 相关)。

可以解释吗?这是预期的还是 DA 中的错误?JPA 是否缓存集合?

稍后,如果在不同的事务中,我尝试获取Collections collectionNew = DA.find("1234").items.size()它返回 2(预期);

4

1 回答 1

0

合并前后 collection1 中的 items.size() 是什么?JPA 实体是常规对象,因此如果大小不是 2,除非您从数据库刷新实体,否则它不会在查找之后。

于 2013-01-30T17:05:25.770 回答