【问题标题】:JPA With Hibernate Error: [PersistenceUnit: JPA] Unable to build EntityManagerFactory带有休眠错误的 JPA:[PersistenceUnit:JPA] 无法构建 EntityManagerFactory
【发布时间】:2013-05-31 02:43:29
【问题描述】:

我对 Java Persistence API 和 Hibernate 有疑问。 我的项目情况是:

我的 persistence.xml 文件是:

<persistence 
    xmlns="http://java.sun.com/xml/ns/persistence"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
    version="2.0">
    <persistence-unit name="JPA">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>
        <class>com.david.Libro</class>
        <class>com.david.Categoria</class>
        <properties>
            <property name="hibernate.show_sql" value="true" />
            <property name="javax.persistence.transactionType" value="RESOURCE_LOCAL" />
            <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
            <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost/arquitecturaJava" />
            <property name="javax.persistence.jdbc.user" value="root" />
            <property name="javax.persistence.jdbc.password" value="root" />
            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect" />
        </properties>
    </persistence-unit>
</persistence>

我在以下位置创建 EntityManagerFactory:

private static EntityManagerFactory buildEntityManagerFactory() 
    {
        try 
        {
            return Persistence.createEntityManagerFactory("JPA");
        } 
        catch (Throwable ex) 
        {
                    ex.printStackTrace();
            //throw new RuntimeException("Error al crear la factoria de JPA:->"+ ex.getMessage());
        }
    }

我的错误是关于创建 EntityManagerFactory:

    javax.persistence.PersistenceException: [PersistenceUnit: JPA] Unable to build EntityManagerFactory
    at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:924)
    at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:899)
    at org.hibernate.ejb.HibernatePersistence.createEntityManagerFactory(HibernatePersistence.java:59)
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:63)
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:47)
    at com.david.JPAHelper.buildEntityManagerFactory(JPAHelper.java:14)
    at com.david.JPAHelper.<clinit>(JPAHelper.java:8)
    at com.david.Categoria.buscarTodos(Categoria.java:93)
    at com.david.FormularioInsertarLibroAccion.ejecutar(FormularioInsertarLibroAccion.java:25)
    at com.david.ControladorLibros.doGet(ControladorLibros.java:38)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99)
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:947)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408)
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1009)
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589)
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    at java.lang.Thread.run(Unknown Source)
Caused by: org.hibernate.DuplicateMappingException: Duplicate class/entity mapping com.david.Libro
    at org.hibernate.cfg.Configuration$MappingsImpl.addClass(Configuration.java:2638)
    at org.hibernate.cfg.AnnotationBinder.bindClass(AnnotationBinder.java:706)
    at org.hibernate.cfg.Configuration$MetadataSourceQueue.processAnnotatedClassesQueue(Configuration.java:3512)
    at org.hibernate.cfg.Configuration$MetadataSourceQueue.processMetadata(Configuration.java:3466)
    at org.hibernate.cfg.Configuration.secondPassCompile(Configuration.java:1355)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1756)
    at org.hibernate.ejb.EntityManagerFactoryImpl.<init>(EntityManagerFactoryImpl.java:96)
    at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:914)
    ... 27 more

Libro 和 Categoria 类的部分代码是:

@Entity
@Table(name = "Categorias")
public class Categoria implements Serializable
{
    private static final long serialVersionUID = 1L;

    @Id
    @JoinColumn(name = "categoria") 
    private String id;
    private String descripcion;

....

@Entity
@Table(name="Libros")
public class Libro implements Serializable
{
    private static final long serialVersionUID = 1L;
    
    @Id
    private String isbn;
    private String titulo;
    @ManyToOne
    @JoinColumn (name="categoria")
    private Categoria categoria;

....

我的休眠配置文件是:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost/arquitecturajava</property>
        <property name="connection.username">root</property>
        <property name="connection.password">root</property>
        <property name="connection.pool_size">5</property>
        <property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
        <property name="show_sql">true</property>
        
        <mapping class="com.david.Categoria"></mapping>
        <mapping class="com.david.Libro"></mapping>
        
    </session-factory>
</hibernate-configuration>

任何想法! 谢谢!!

【问题讨论】:

  • 重新抛出异常时,如果将原始异常作为嵌套异常包含在内会更有用,因此可以检查原始堆栈跟踪:new RuntimeException("my message", ex)
  • 在抛出新的 RuntimeException 之前,使用ex.printStackTrace(); 打印堆栈跟踪,或者使用@SJuan76 评论的(更好的)策略。
  • 你不应该抓到任何东西。如果 EntityManagerFactory 创建失败,您无论如何都无法恢复。
  • 我已经修改,PrintOfTrace 的错误显示。但是同样的我不知道如何解决这个错误。
  • 您的错误是:DuplicateMappingException: Duplicate class/entity mapping com.david.Libro,如您的堆栈跟踪中的Caused by 行所示。

标签: eclipse hibernate jpa-2.0 entitymanager


【解决方案1】:

在这种情况下,您不需要同时使用 hibernate.cfg.xmlpersistence.xml。您是否尝试过删除 hibernate.cfg.xml 并仅映射 persistence.xml 中的所有内容?

但正如另一个答案也指出的那样,这样不行:

@Id
@JoinColumn(name = "categoria") 
private String id;

您不想改用@Column 吗?

【讨论】:

  • 如果您不添加@Column,Hibernate 会将您的所有属性捕获为列。如果我删除 hibernate.cfg.xml 我无法访问我的 BD。 " /hibernate.cfg.xml 未找到"
  • 另一方面,如果我不删除 hibernate.cfg.xml 和 persistence.xml 中的注释类链接,错误是“事务未激活”
  • 也看看这篇文章:stackoverflow.com/questions/3807503/… 你不需要两者。您应该使用您的 persistence.xml。但也许它没有正确配置!但问题是因为我告诉你的我猜:)
  • 好吧,Hibernate 的一部分是真的。它需要删除hibernate.cfg.xml。但我的错误:“javax.persistence.PersistenceException: [PersistenceUnit: JPA] Unable to build EntityManagerFactory”和“Duplicate class/entity mapping com.david.Libro”无法解决...
  • 终于找到了!!禁止 hibernate.cfg.xml 和 hbm 文件,但不删除 @JoinColumn 注释。谢谢!!
【解决方案2】:

抑制Categoria类的ID字段上的@JoinColumn(name="categoria"),我认为它会起作用。

【讨论】:

  • 是一样的,在Categoria或者Libro中带o没有这行,报错是一样的。
  • 删除 hibernate.cfg.xml 并删除 @JoinColumn 注释 od Categoria 后,错误是“org.hibernate.DuplicateMappingException: Duplicate class/entity mapping com.david.Libro”...我不知道不知道为什么..
【解决方案3】:

如果有人面对:--org.hibernate.jpa.HibernatePersistenceProvider 持久性提供者尝试为 paymentenginePU 持久性单元创建容器实体管理器工厂时,请使用上述注释。发生以下错误:[PersistenceUnit: paymentenginePU] Unable to build Hibernate SessionFactory ** 如果您使用的是审核表,这是一个解决方案。@Audit

在超类上使用:- @Audited(targetAuditMode = RelationTargetAuditMode.NOT_AUDITED)。

【讨论】:

    【解决方案4】:

    在 pom 中添加以下依赖项后,它对我有用,

    <dependency>
     <groupId>org.hibernate</groupId>
     <artifactId>hibernate-validator</artifactId>
     <version>4.3.0.Final</version>
    </dependency>
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-07-28
      • 2012-06-16
      • 2012-04-19
      • 1970-01-01
      相关资源
      最近更新 更多