我现在对一小段代码感到疯狂。 我正在创建一个基于spring MVC 3.2的simpel rest服务,并使用带有spring-orm和hibernate4.1.9的JPA持久层。
我正面临一个关于未映射类的奇怪错误。这是我的第一个实体(在我建立关系之前完美地运作)
User.java
@Entity
@Table(name="user")
public class User {
//[...]
@OneToMany(mappedBy="owner", cascade=CascadeType.ALL, fetch=FetchType.EAGER)
private Set<FileInfo> fileInfos;
//[...]
}
FileInfo.java
@Entity
@Table(name="file_info")
public class FileInfo {
//[...]
@ManyToOne
@JoinColumn(name = "owner_id")
private User owner;
//[...]
}
Servlet配置
<?xml version="1.0" encoding="UTF-8"?>
<!--[...]-->
<context:component-scan base-package="org.mypackage.myapp" />
<!--[...]-->
<bean id="sessionFactory"
class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="configLocation">
<value>classpath:hibernate.cfg.xml</value>
</property>
<property name="packagesToScan" value="org.mypackage.myapp.model" />
<property name="configurationClass">
<value>org.hibernate.cfg.AnnotationConfiguration</value>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">${jdbc.dialect}</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
</bean>
<!--[...]-->
<tx:annotation-driven />
<bean id="transactionManager"
class="org.springframework.orm.hibernate4.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
<!--[...]-->
错误追踪
Caused by: org.hibernate.AnnotationException: Use of @OneToMany or @ManyToMany targeting an unmapped class: org.mypackage.myapp.model.User.fileInfos[org.mypackage.myapp.model.FileInfo]
at org.hibernate.cfg.annotations.CollectionBinder.bindManyToManySecondPass(CollectionBinder.java:1057)
at org.hibernate.cfg.annotations.CollectionBinder.bindStarToManySecondPass(CollectionBinder.java:733)
at org.hibernate.cfg.annotations.CollectionBinder$1.secondPass(CollectionBinder.java:668)
at org.hibernate.cfg.CollectionSecondPass.doSecondPass(CollectionSecondPass.java:66)
at org.hibernate.cfg.Configuration.originalSecondPassCompile(Configuration.java:1597)
at org.hibernate.cfg.Configuration.secondPassCompile(Configuration.java:1355)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1737)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1788)
at org.springframework.orm.hibernate4.LocalSessionFactoryBuilder.buildSessionFactory(LocalSessionFactoryBuilder.java:242)
at org.springframework.orm.hibernate4.LocalSessionFactoryBean.buildSessionFactory(LocalSessionFactoryBean.java:372)
at org.springframework.orm.hibernate4.LocalSessionFactoryBean.afterPropertiesSet(LocalSessionFactoryBean.java:357)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1545)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1483)
有谁知道问题出在哪里。我对这项技术没有太多经验,我不确定这篇文章中提供的信息是否足够。
感谢您的帮助!
编辑:
这是我的hibernate.cfg.xml
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<mapping package="org.mypackage.myapp.model"/>
<mapping class="org.mypackage.myapp.model.User"/>
<mapping class="org.mypackage.myapp.model.FileInfo"/>
<mapping class="org.mypackage.myapp.model.Group"/>
<mapping class="org.mypackage.myapp.model.FileInfoGroup"/>
</session-factory>
</hibernate-configuration>
ollie314
答案 0 :(得分:0)
行, 我终于找到了应用程序在部署期间生成错误的原因!。
我可能在配置过程中出错了。我正在配置一个spring-servlet文件,并且没有看到我的spring配置文件夹中还有另一个配置文件名为root-context.xml。它在我的项目配置期间由STS自动生成(可能是由于我操作不当),这是服务器用来部署应用程序的文件。在此文件中,我的会话工厂bean未正确配置。因此,在修复错误之后,每个方面都能完美运行。
注意:我不确定hibernate.cfg.xml与spring的必要性,因为一切都可以在root spring配置文件中完成。在我看来,只有当项目定义了多次会话工厂时才需要它。根据DRY模式,hibernate.cfg,xml在这种情况下是相关的。有人可以告诉我,如果我错了吗?