冬眠。在更新子列表中删除

2024-03-06

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

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

我了解到orhanRemoval,但它无济于事,因为父对象必须处于“托管”状态(所以clear()在子集合上不起作用),而不是像我的示例中那样处于瞬态。


The update or 保存或更新()方法不关心数据库中对象的当前状态,而是更新对象的所有当前属性。因此,在您的情况下,当您用其集合更新新对象时,它不会照顾旧集合,而是会更新对象的新集合。因此,数据库中同时拥有旧集合和新集合。

要用新集合覆盖旧集合,您应该使用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 个子级。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

冬眠。在更新子列表中删除 的相关文章

随机推荐