我试图让问题更小,但我无法让它更小:(
我有 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(预期);