我@ManyToOne在Hibernate中有标准关联.更新时,我正在创建新实体(使用new关键字)并填入必要的值(ID也已插入).值来自UI.以同样的方式,我创建了新的子对象集合,通过值(也插入了ID)填充每个子对象,并在父对象中存储集合(使用setter或addAll()方法).
所以我的问题是:在更新父集合时如何删除父集合中的所有对象,并用新集合替换它们.在新的集合中,一些对象是新的,有些只需要更新(它们已插入ID).
我学到了orhanRemoval,但它无能为力,因为父对象必须处于"托管"状态(所以clear()对子集合不起作用),而不是像我的例子那样处于瞬态状态.
小智 9
该更新或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);
Run Code Online (Sandbox Code Playgroud)
上面的代码导致数据库中有1个子节点.如果将merge()方法更改为saveOrUpdate()方法,则会在数据库中生成2个子项.