一尘不染

hibernate。从更新子列表中删除

hibernate

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

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

我了解了有关信息orhanRemoval,但是它无济于事,因为父对象必须处于“托管”状态(因此clear()子集合将无法工作),而不是如我的示例那样处于过渡状态。


阅读 335

收藏
2020-06-20

共1个答案

一尘不染

更新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个子级。

2020-06-20