我的 Java 应用程序的 DAO 层中有以下方法:
public void save(Employee emp) {
System.out.println("emp type: " + emp.getClass().getName);
getHibernateTemplate().save(emp);
System.out.println("object saved!");
System.out.flush();
}
雇员类不从任何其他类扩展,并具有以下 hbm 文件:
<hibernate-mapping>
<class name="org.myCompany.Employee" table="employee">
<!-- fields omitted to save space -->
</hibernate-mapping>
然而插入失败并出现 java.lang.ClassCastException。起初,我认为我的映射有问题(比如整数映射到布尔值),但后来我打开了 hibernate 的 show_sql 调试,并在我的日志文件中发现了以下内容:
emp 类型:org.myCompany.Employee
休眠:插入客户(.......)值(......)
java.lang.ClassCastException
为什么它选择一个完全随机的表来插入?我确定我一定有一些配置文件配置错误,但我不知道是哪一个。我检查了以下内容:
- applicationContext-hibernate.xml -> Customer 和 Employee 对象都映射到它们正确的 hbm 文件
- Customer 和 Employee 都没有继承关系(甚至没有像 Person 或 User 这样的公共父类)
我还能尝试什么?