Hibernate:merge()在update()上的缺点
我在NonUniqueObjectException
Hibernate抛出问题上遇到了问题。
阅读文档和这篇]博客文章,我替换了从update()
到的调用merge()
,它解决了问题。
我相信我了解例外的原因,以及为什么更改方法可以解决不相关对象和会话边界方面的问题。
我的问题是:鉴于merge()
始终将解析为会话对象,或者如果它不存在,则将其检索,因此调用merge()通常是比update()
?
使用merge()
over 的缺点是update()
什么?
回答:
调用merge()通常比update()更安全吗?
作为避免NonUniqueObjectException的一种方法,可以。我认为这可以解释为什么JPA不允许使用更新方法。
在update()上使用merge()的缺点是什么?
未经建议的用户可能会认为他或她拥有新的管理实体。就像是
// myEntity (passed as parameter does not become managed)// Only the one returned by the merge operation is a managed entity
session.merge(myEntity);
// "newValue" is not commited because myEntity is not managed
myEntity.setMyProperty("newValue");
而且,如果您的持久性上下文不包含您的实体,则 默认行为。但这是可以避免的
- 添加一个版本(@Version)列。0或NULL版本 ,必须插入而不是更新
- 使用Hibernate拦截器
- 如果确定要更新而不是插入,则可以使用以下方法
…
public void updateMyEntity(MyEntity updateableMyEntity); // load does not hit the database
MyEntity myEntity = (MyEntity) session.load(MyEntity.class, updateableMyEntity.getId());
BeanUtils.copyProperties(myEntity, updateableMyEntity);
}
这样,您无需合并或更新方法即可更新实体。有关更多信息,请参见此问题:在Hibernate上更新分离对象的某些字段的最佳方法?
以上是 Hibernate:merge()在update()上的缺点 的全部内容, 来源链接: utcz.com/qa/404978.html