所以我有这些表:ocurrencia 和 persona,它们有多对多的关系。此表称为标识。我正在使用休眠。
这是 ocurrencia 上的代码
@ManyToMany(fetch = FetchType.EAGER, cascade = CascadeType.ALL)
@JoinTable(name = "identificacion", joinColumns = {
@JoinColumn(name = "id_ocurrencia", nullable = false, updatable = false) },
inverseJoinColumns = { @JoinColumn(name = "id_persona",
nullable = false, updatable = false) })
private List<Persona> personas
;
这是关于角色的代码
// bi-directional many-to-one association to Identificacion
@ManyToMany(fetch = FetchType.LAZY, mappedBy = "persona")
private List<Ocurrencia> ocurrenciasIdentificacion;
我尝试在 Ocurrencia 上使用 Fetchtype Lazy,但遇到了一些问题,所以我使用了 EAGER。我也应该在角色上使用 EAGER 吗?好吧,当我尝试保存 ocurrencia 时,我的问题来了,这不是我主要关心的问题。所以我添加了一个角色的选择菜单,其中有一个按钮,上面写着“添加一个人”,所以如果他们选择角色并点击“添加一个人按钮”,它会转到 ocurrencia.getPersonas().add(newPersona) 和它在表单上正确显示(在点击保存之前),当我编辑任何我以前记录的 ocurrencias 时,它就像一个魅力,但是当我创建一个新的 Ocurrencia 时,我没有收到错误,但一切都崩溃了,它是不在数据库中插入任何新记录。
当我尝试添加一个没有角色的新 ocurrencia 并且它起作用时,我正在失去理智,它出现在我的数据库中。所以我认为它无法在表标识上插入任何内容,因为它没有来自 ocurrencia 的主键。
这是我创建表的新记录的 GenericDao 函数
public void crear(final T o)throws EntidadNoGrabadaException{
try {
em.persist(o);
} catch (final PersistenceException e) {
throw new EntidadNoGrabadaException("Error al grabar: ".concat(o
.toString()), e);
}
}
我能想到的唯一解决方案是手动创建一个用于识别的模型类,并与 ocurrencia 和角色建立多对一的关系。我想我必须添加一个主键。但这似乎是一种解决方案,如果我们最终这样做,为什么我们会有多对多的选择。
编辑我刚发现这个,
http://www.mkyong.com/hibernate/hibernate-many-to-many-example-join-table-extra-column-annotation/
我没有关于身份的额外专栏,这是解决此问题的唯一方法吗?谢谢
更新
我将 mappedby="persona" 更改为 mappedby="personas" 现在我发现了这个错误
23:27:20,334 ERROR [stderr] (http-localhost-127.0.0.1-8080-6) ec.edu.puce.biologia.excepciones.EntidadNoGrabadaException: Error al grabar: ec.edu.puce.biologia.model.Ocurrencia@22231361 persistence error org.hibernate.PersistentObjectException: detached entity passed to persist: ec.edu.puce.biologia.model.Persona
23:27:20,335 ERROR [stderr] (http-localhost-127.0.0.1-8080-6) at ec.edu.puce.biologia.dao.impl.GenericDao.crear(GenericDao.java:68)
23:27:20,335 ERROR [stderr] (http-localhost-127.0.0.1-8080-6) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
23:2