beg*_*er_ 3 hibernate jpa unique-constraint
我有一个具有唯一字段的实体 A,该字段基本上定义了实体,这意味着它是相等的,那么实体也完全相同。
第二点是,如果违反该约束,则绝不是例外。这意味着完全可以预期用户会尝试输入重复项。
在重复的情况下,应用程序应该默默地选择已经存在的实体。我的问题现在是我应该做什么,特别是在保存包含 As 列表的实体时。
我不确定这是否容易实现,因为 DataIntegrityViolationException 不包含任何易于处理的信息,例如在级联持续的情况下受影响的实体!!!
我更喜欢这个,但是有相当大的开销,因为在每个插入之前可能有多个选择(存在检查)。
什么是更好的方法?
对于选项 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 没有很好的解决方案。
| 归档时间: |
|
| 查看次数: |
3985 次 |
| 最近记录: |