53

我有以下配置:

<bean id="entityManagerFactory"
        class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="dataSource" ref="jpaDataSource" />
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" />
        </property>
        <property name="jpaProperties">
            <props>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
                <prop key="hibernate.show_sql">true</prop>
            </props>
        </property>
        <property name="packagesToScan">
        <list>
            <value>com.example.domain</value>
            <value>com.example.repositories</value>
        </list>
    </property>
</bean>

我在 com.example.domain 中有我的 Geoname 类:

@Entity
@Table(name="geonames")
public class Geoname implements Serializable {

    @Id
    @Column(name="geonameid")
    private Long geonameid = null;
}

然而,在运行时,我得到以下异常:

引起:org.hibernate.AnnotationException:没有为实体指定标识符:com.example.domain.Geoname at org.hibernate.cfg.InheritanceState.determineDefaultAccessType(InheritanceState.java:277) at org.hibernate.cfg.InheritanceState.getElementsToProcess( InheritanceState.java:224) 在 org.hibernate.cfg.AnnotationBinder.bindClass(AnnotationBinder.java:664) 在 org.hibernate.cfg.Configuration$MetadataSourceQueue.processAnnotatedClassesQueue(Configuration.java:3449) 在 org.hibernate.cfg.Configuration $MetadataSourceQueue.processMetadata(Configuration.java:3403) 在 org.hibernate.cfg.Configuration.secondPassCompile(Configuration.java:1330) 在 org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1730)

任何想法为什么?

旁注:我在这个项目中结合了 mongodb 和 hibernate/mysql。

4

3 回答 3

229

我有以下

import org.springframework.data.annotation.Id;

自然应该是:

import javax.persistence.Id;

感谢@JB Nizet

于 2013-03-10T15:22:07.293 回答
12

我遇到了同样的错误。我解决了它并发现我没有在我的实体类的 id 字段中添加@Id 注释。

@Entity
@Table(name="geonames")
public class Geoname implements Serializable {

    @Column(name="geonameid")
    private Long geonameid = null;
}
于 2018-07-11T16:39:55.750 回答
-3

试试这个

  @Column(name="geonameid",unique=true,nullable=false)
于 2013-03-10T08:35:07.113 回答