我有一个包含其他两个具有@ManyToOne关系的实体的实体。
@Entity
public class A extends Serializable{
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
private Long id;
@ManyToOne
@Cascade(CascadeType.SAVE_UPDATE)
private B b;
@ManyToOne
@Cascade(CascadeType.SAVE_UPDATE)
private C c;
}
如果我尝试保存一个具有另一个A记录的“ B_ID”和“ C_ID”的A实例,则会出现异常:
org.hibernate.NonUniqueObjectException:具有相同标识符值的另一个对象已与会话关联
例如:
A table
| ID | B_ID | C_ID |
| 1 | 1 | null | // this works
| 2 | null | 1 | // this works
| 3 | 1 | x | // this throws the exception
| 4 | x | 1 | // this throws the exception
x=any value of existent B/C_ID
B_ID和C_ID在我的模型中不是唯一的,并且(B_ID + C_ID)不是唯一的约束!
我能做什么?
预先感谢。
Hibernate在这里并没有抱怨数据库的唯一性,而是在抱怨当前Session
对象已经包含了一个与您要保存的新对象具有相同ID的对象。这是不允许的-
Hibernate严格要求给定的ID不能在单个会话的范围内用两个不同的对象表示。
在某个时候,您的应用程序已保存了具有相同ID的实体,并且该对象已在会话中“注册”。在这种特定情况下,很难分辨出它在抱怨哪个ID,因为异常文本不清楚。尝试暂时删除级联伪指令,看看它是否仍然存在,请尝试缩小范围。
如有必要,您可以强制会话“忘记”给定ID的任何现有对象(Session.evict()
在Hibernate
API或EntityManager.detach()
JPA 2.0 API中使用),但这不是一个很好的解决方案。
重申一下-该异常与数据库约束完全无关,它与Hibernate保护其内部内存状态的一致性有关。
是否可以使用Hibernate ORM和OGM创建单个应用程序?我创建了一个应用程序,我在一个应用程序中遇到了多个JPA的问题。我通过更改两个JPA的名称解决了这个问题,但两个JPA之间仍然存在冲突。以下是例外情况: 原因:org.springframework.beans.factory.无法将类型[org.hibernate.internal.SessionFactoryImpl]的参数值转换
问题内容: 我如何获得Spring来从中加载Hibernate的属性? 我们正在使用Spring和JPA(以Hibernate作为实现)。Spring 指定了JPA语言和Hibernate属性: 在这种配置中,Spring通过applicationContext.xml读取所有的Hibernate属性。当我创建一个(位于我的类路径的根,与META- INF处于同一级别)时,Hibernate根本不
我正在做一个项目,使用Hibernate和Jackson来序列化我的对象。我想我理解它是如何工作的,但我无法让它工作。 如果我理解得很好,只要关系获取模式设置为LAZY,如果你想要这个关系,你就必须初始化它。 这是我的课: 还有所有的能手和二传手。 我也试过这个作为类注释。还尝试了非空。然而,杰克逊一直派我去
问题内容: 目前,我正在使用Spring Web服务,hibernate和JAXb进行项目。 1)我使用IDE的“hibernate代码生成”生成了hibernatebean, 2)另外,我已经使用maven编译器生成了jaxb bean。 .. 现在,我的问题是 1)这是正确的方法吗?(有那么多豆子)。 2)我应该使用JAXb bean来处理到服务层吗?如何使各层解耦? 3)或者,我是否需要创建
问题内容: 如果有什么问题请指正。 现在,当我们将Spring DAO用于ORM模板时,当我们使用@Transactional属性时,从外部而不是在方法内部调用该方法时,我们将无法控制事务和/或会话。 延迟加载可节省资源-减少对数据库的查询,减少将所有集合保持在应用程序内存中的内存。 因此,如果lazy = false,则在链接集中有10,000条记录的情况下,所有相关联的集合都将被提取,这并不是
问题内容: 我们都知道使用Hibernate时的默认行为-它使实际数据库序列增加 一 ,将该值乘以50(默认值)-然后将该值用作实体ID。 这是错误的行为,并与说明以下内容的规范冲突: distributionSize-(可选)从序列中分配序列号时要增加的数量。 需要明确的是:我不关心生成的ID之间的差距。 我关心与基础数据库序列 不一致的 ID 。例如:任何其他应用程序(例如,使用纯JDBC)可