【问题标题】:Error: Deprecated PersistenceProvider, use HibernatePersistenceProvider instead of HibernatePersistence错误:不推荐使用 PersistenceProvider,使用 HibernatePersistenceProvider 而不是 HibernatePersistence
【发布时间】:2023-03-21 18:18:01
【问题描述】:

我认为对于像我这样的初学者来说,这是一个非常普遍的问题。但我找不到解决方案。然而。

文件 persistence.xml 位于 src/META-INF/persistence.xml

<?xml version="1.0" encoding="UTF-8"?>
    <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="jobs">

    <!-- provedor/implementacao do JPA -->
    <provider>org.hibernate.ejb.HibernatePersistenceProvider</provider>

    <!-- entidade mapeada -->
    <class>
        br.com.caelum.tarefas.modelo.Job
    </class>

    <properties>
        <!-- dados da conexao -->
        <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
        <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost/fj21" />
        <property name="javax.persistence.jdbc.user" value="root" />
        <property name="javax.persistence.jdbc.password" value="root" />

        <!-- propriedades do hibernate -->
        <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect" />
        <property name="hibernate.show_sql" value="true" />
        <property name="hibernate.format_sql" value="true" />

        <!-- atualiza o banco, gera as tabelas se for preciso -->
        <property name="hibernate.hbm2ddl.auto" value="update" />

    </properties>
</persistence-unit>

当我运行代码时

try
{
    EntityManagerFactory factory = Persistence.createEntityManagerFactory("tarefas");
    EntityManager manager = factory.createEntityManager();

    manager.close();
    factory.close();
    System.out.println("Execução com sucesso!");
}catch(Exception _Ex)
{
    System.out.println("Erro: " + _Ex.getMessage());
}

我收到消息

27/03/2014 11:35:18 org.hibernate.ejb.HibernatePersistence logDeprecation WARN: HHH015016: Encountered a deprecated javax.persistence.spi.PersistenceProvider [org.hibernate.ejb.HibernatePersistence]; use [org.hibernate.jpa.HibernatePersistenceProvider] instead.
27/03/2014 11:35:18 org.hibernate.ejb.HibernatePersistence logDeprecation WARN: HHH015016: Encountered a deprecated javax.persistence.spi.PersistenceProvider [org.hibernate.ejb.HibernatePersistence]; use [org.hibernate.jpa.HibernatePersistenceProvider] instead.
27/03/2014 11:35:18 org.hibernate.ejb.HibernatePersistence logDeprecation WARN: HHH015016: Encountered a deprecated javax.persistence.spi.PersistenceProvider [org.hibernate.ejb.HibernatePersistence]; use [org.hibernate.jpa.HibernatePersistenceProvider] instead.
Erro: No Persistence provider for EntityManager named jobs

我做错了什么?

【问题讨论】:

标签: java hibernate


【解决方案1】:

问题出在 persistence.xml 文件的这一行中:

<!-- provedor/implementacao do JPA -->
<provider>org.hibernate.ejb.HibernatePersistenceProvider</provider>

应该改成

<!-- provedor/implementacao do JPA -->
<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>

即使persistence.xml中缺少provider标签,由于Hibernate bug,Hibernate会使用旧的ejb provider实现,然后它会抱怨(精神分裂症)

【讨论】:

  • 当我将提供程序更改为“org.hibernate.jpa.HibernatePersistenceProvider”时,我得到一个“javax.ejb.EJBException:java.lang.NullPointerException”。使用旧提供程序时,一切运行良好...(JBoss EAP 6.1)。其他人有这个问题吗?
  • 对于像我这样没有通过眼睛发现它的人:.ejb。 -> .jpa.
【解决方案2】:

aurelije 的解决方案是正确的,但是即使您指定了正确的HibernatePersistenceProvider,Hibernate 中的错误也会错误地报告问题: 有关该错误的所有详细信息都可以在 bug report HHH-9141 中找到,并且存在于 Hibernate EntityManager 版本 4.3.5.Final 中。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2012-08-03
    • 2019-02-28
    • 2019-08-23
    • 2020-04-05
    • 2014-11-04
    • 2020-04-14
    • 1970-01-01
    • 2015-06-29
    相关资源
    最近更新 更多