休眠。删除更新子列表

时间:2013-11-18 20:54:02

标签: hibernate jpa orm

我在Hibernate中有标准的@ManyToOne关联。更新时,我正在创建新实体(使用new关键字)并填入必要的值(ID也已插入)。值来自UI。以同样的方式,我创建了新的子对象集合,通过值(也插入了ID)填充每个子对象,并在父对象中存储集合(使用setter或addAll()方法)。

所以我的问题是:在更新父级时如何删除父级集合中的所有对象,并用新集合替换它们。在新的集合中,一些对象是新的,有些只需要更新(它们已插入ID)。

我了解了orhanRemoval,但它无能为力,因为父对象必须处于“托管”状态(因此{child}上的clear()将无效),而不是处于瞬态状态我的例子..

1 个答案:

答案 0 :(得分:9)

update saveOrUpdate()方法不会关注数据库中对象的当前状态,而是更新对象的所有当前属性。因此,在您的情况下,当您使用其集合更新新对象时,它不会关注旧集合,它将更新对象的新集合。因此,您在数据库中同时拥有旧集合和新集合。

要用新的集合覆盖旧集合,您应该使用 merge()方法,该方法首先将具有相同id的对象加载到持久化上下文中,然后复制状态将分离的对象分配给持久对象,然后它会考虑对象是否脏。如果是这样,它将持续更新新对象。

以下代码可能会演示上述说明:

    // Initial the persistent layer
    DAOLayer daoLayer = new DAOLayer();

    // Persist the parent object with 1 child
    Parent parent = new Parent("parent");
    parent.addChild(new Child("child"));
    Parent persistentParent = daoLayer.merge(parent);

    // Create the new parent object with the same Id stored in DB
    Parent newParent = new Parent("parent");
    newParent.setId(persistentParent.getId());
    newParent.addChild(new Child("child"));

    // Update the new parent object
    persistentParent = daoLayer.merge(newParent);

上面的代码导致数据库中有1个子节点。如果将merge()方法更改为saveOrUpdate()方法,则会在数据库中生成2个子项。