3

我有一个具有唯一字段的实体 A,该字段基本上定义了实体,这意味着它相等,然后实体也完全相同。

第二点是,如果违反了该约束,我们绝不会说例外。这意味着完全可以预期用户会尝试输入重复项。

在重复的情况下,应用程序应该默默地选择已经存在的实体。我现在的问题是我应该做什么,尤其是在保存包含 As 列表的实体时。

  • 抓住异常并从那里开始

我不确定这是否容易实现,因为 DataIntegrityViolationException 不包含任何易于处理的信息,例如在 Cascaded persist 的情况下受影响的实体!!!

  • 保存前检查(持久化)并将提交的实体替换为现有实体(设置了 id)

我更喜欢这个,但是有相当大的开销,因为在每次插入之前可能有多个选择(存在检查)。

更好的方法是什么?

4

1 回答 1

5

对于选项 1),您正在寻找类似http://dev.mysql.com/doc/refman/5.5/en/insert-on-duplicate.html但该命令在 JPA/hibernate 级别没有等效项(我不要认为那是 ANSI SQL)。试图捕捉异常并“从那里开始”是一个坏主意,因为事务将被回滚,您将不得不经历许多问题才能使其表现得像您想要的那样。

对于选项 2),我认为这是标准的 JPA/hibernate 实践,您不仅需要查询并可能从 DB 加载实体,还需要将更改从瞬态对象复制到加载的对象,然后让 JPA 保存你的更新。这很麻烦,您必须小心您所依赖的任何级联操作,因为您可能需要避免用瞬态对象覆盖持久对象。这是一个复杂的问题,JPA/Hibernate 没有很好的解决方案。

于 2013-03-31T16:17:31.167 回答