JPA (Hibernate) + Spring:处理唯一约束违规

beg*_*er_ 3 hibernate jpa unique-constraint

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

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

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

  • 只需捕获异常并从那里开始

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

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

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

什么是更好的方法?

ilc*_*ero 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 没有很好的解决方案。