我当前的Hibernate项目存在一些映射问题。但首先,我要告诉大家我正在使用:
NetBeans 7.1.1
Java
JSF2
Oracle 10g
Apache Tomcat 7.0.22
Hibernate 3.2.1
我不得不说,所有的映射类都是由Hibernate反向工程向导使用Annotations生成的,我的意思是,这些类是从数据库中的表中构建的。我可以正确运行程序,除了关于在OneToMany关系中插入的部分,这个:
类别
主
@Entity
@Table(name = "EXP_EXPEDIENTES")
public class ExpExpedientes implements Serializable {
@Id
@SequenceGenerator(name = "seq", sequenceName = "EXP_SEQ") //Triggers are disabled so Hibernate can manage the sequence generation.
@GeneratedValue(generator = "seq")
@Column(name = "ID_EXP")
private long idExpediente;
@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)
private Set<ExpInstrucciones> expInstrucciones;
//more fields
//getters & setters
详细信息
@Entity
@Table(name = "EXP_INSTRUC")
public class ExpInstrucciones implements Serializable {
@Id
@SequenceGenerator(name="seq",sequenceName="EXP_SEQ")
@GeneratedValue(generator="seq")
@Column(name = "ID_INS")
private long idInstruccion;
@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="ID_EXP", nullable=false)
private ExpExpedientes expExpedientes;
//more fields
//getters & setters
通过这种方式,我可以创建一个ExpExpediente对象和几个ExpInstrucciones对象。在分配了一些值之后,在尝试保存它们之前,我会:
/* Previously, I've created these objects:
* expInst_1 = new ExpInstruccines();
* expInst_2 = new ExpInstrucciones();
*/
expInst_1.setExpExpedientes(expExpediente);
expInst_2.setExpExpedientes(expExpediente);
expExpediente.getExpInstrucciones().add(expInst_1);
expExpediente.getExpInstrucciones().add(expInst_2);
ExpedienteDAO.save(expExpediente);
DAO类中的save方法只包含会话.save(expdiente)。这就是我的问题所在。通过阅读Hibernate生成的sql,我可以发现当Hibernate尝试执行下一句话时,出现了ORA-00942:表或视图不存在错误:
insert
into
EXP_EXPEDIENTES_EXP_INSTRUC
(EXP_EXPEDIENTES_ID_EXP, expInstrucciones_ID_INS)
values
(?, ?)
我认为错误与表EXP_EXPEDIENTES_EXP_INSTRUC有关,该表显然不存在于数据库中。事实上,正如我已经说过的,映射是从数据库中生成的。
现在,我的问题是:我应该创建那个表吗?或者所有这些问题都是由于配置错误造成的?我真的不知道该怎么办,所以任何帮助都将不胜感激。
您的映射应该如下所示:
@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY,
mappedBy = "expExpedientes")
private Set<ExpInstrucciones> expInstrucciones;
双向关系的侧应该使用@OneToMany
侧的mappedBy
属性连接,否则ExpExpedientes
和ExpInstrucciones
之间将有两个单向关系,其中一个使用外键实现,另一个使用联接表(默认情况下)。
我想这是休眠反向工程向导的错误,您也应该检查其他关系是否存在此问题。