Предупреждение об устаревании JPA 2.1/Hibernate 4.3

Я использую JPA 2.1 образец приложения с Hibernate 4.3.x реализацией.

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence
                                http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
    <persistence-unit name="unit1">

        <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
        <class>net.roseindia.model.Product</class>
        <properties>
            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"/>
            <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/common"/>
            <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
            <property name="hibernate.connection.username" value="root"/>
            <property name="hibernate.connection.password" value="root"/>
            <property name="hibernate.show_sql" value="true"/>
            <property name="hibernate.format_sql" value="true"/>
        </properties>

    </persistence-unit>
</persistence>

В pom.xml у меня есть следующая зависимость.

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-entitymanager</artifactId>
    <version>4.3.5.Final</version>
</dependency>

Пример приложения командной строки работает нормально (это очень просто), но при запуске я получаю следующее предупреждающее сообщение.

Apr 13, 2014 1:12:43 PM org.hibernate.ejb.HibernatePersistence logDeprecation
WARN: HHH015016: Encountered a deprecated javax.persistence.spi.PersistenceProvider [org.hibernate.ejb.HibernatePersistence]; use [org.hibernate.jpa.HibernatePersistenceProvider] instead.

Итак, проблема в моей неправильной конфигурации (и можно ли этого избежать?) или проблема в реализации Hibernate?

ОБНОВЛЕНО

Вот код, который я использую:

import net.roseindia.model.Product;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;

public class AppTest {

private static final String PERSISTENCE_UNIT_NAME = "unit1";
private static EntityManagerFactory factory;

public class AppTest {

    private static final String PERSISTENCE_UNIT_NAME = "unit1";
    private static EntityManagerFactory factory;

    public static void main(String[] args) {
        factory = Persistence.createEntityManagerFactory(PERSISTENCE_UNIT_NAME);
        EntityManager em = factory.createEntityManager();

        em.getTransaction().begin();

        Product product = new Product();
        product.setProductName("JPA 2.1 Book");
        product.setProductDescription("This is the latest book on JPA 2.1");
        product.setStockQty(100.00);
        product.setPrice(95.99);
        em.persist(product);
        em.getTransaction().commit();
        em.close();
        factory.close();

    }
}

person Ashot Karakhanyan    schedule 13.04.2014    source источник
comment
Покажите нам, как вы создаете EntityManagerFactory. Где-то вы используете старый org.hibernate.ejb.HibernatePersistence вместо нового org.hibernate.jpa.HibernatePersistenceProvider. Простой поиск в вашем коде должен позволить вам найти его.   -  person JB Nizet    schedule 13.04.2014
comment
@JBNizet, я обновил класс бега. Это достаточно?   -  person Ashot Karakhanyan    schedule 13.04.2014
comment
Похоже на ошибку. Возможно, hibernate.atlassian.net/browse/HV-863. Или загруженный файл persistence.xml на самом деле не тот, который вы нам показываете.   -  person JB Nizet    schedule 13.04.2014
comment
Нет, я предоставляю то же самое, что и я. И да, я также обнаружил некоторые похожие проблемы (community. jboss.org/thread/233644), но не для версии hibernate 4.3.x Вот я и подумал, что что-то не так делаю. В любом случае большое спасибо.   -  person Ashot Karakhanyan    schedule 13.04.2014
comment
Вы используете Весну? Может быть jira.spring.io/browse/SPR-11240   -  person GreyBeardedGeek    schedule 13.04.2014
comment
Нет, @GreyBeardedGeek, это простой код командной строки. Да, я собираюсь стать согласен, что это ошибка.   -  person Ashot Karakhanyan    schedule 13.04.2014


Ответы (3)


Для пользователей Spring, у которых возникла эта проблема, вот что происходит: даже когда ребята из Spring решили проблему с классом HibernateJpaVendorAdapter, вам на самом деле нужно сообщить вашей JPA EntityManagerFactory, чтобы использовать этот класс . Я удалил предупреждение со следующей конфигурацией (обратите внимание, я указал bean-компонент для jpaVendorAdapter):

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalEntityManagerFactoryBean">
    <property name="persistenceUnitName" value="goal-control-unit" />
    <property name="jpaDialect">
        <bean class="cl.antica.goalcontrol.util.ExtendedHibernateJPADialect" />
    </property>
    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"/>
    </property> 
</bean>

Я отладил ваш код, и кажется, что устаревший класс автоматически загружается классом Persistence. Это фактический код createEntityManagerFactory, который вызывается, когда вы вызываете его, передавая только имя единицы сохраняемости:

public static EntityManagerFactory createEntityManagerFactory(String persistenceUnitName, Map properties) {
    EntityManagerFactory emf = null;
    List<PersistenceProvider> providers = getProviders();
    for ( PersistenceProvider provider : providers ) {
        emf = provider.createEntityManagerFactory( persistenceUnitName, properties );
        if ( emf != null ) {
            break;
        }
    }
    if ( emf == null ) {
        throw new PersistenceException( "No Persistence provider for EntityManager named " + persistenceUnitName );
    }
    return emf;
}

Метод getProviders() включает org.hibernate.ejb.HibernatePersistence по умолчанию в качестве первого возможного поставщика (я думаю, в качестве запасного решения). Я бы сделал что-то вроде этого:

import java.util.List;
import java.util.Map;

import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.PersistenceException;
import javax.persistence.spi.PersistenceProvider;
import javax.persistence.spi.PersistenceProviderResolverHolder;

import org.hibernate.ejb.HibernatePersistence;

@SuppressWarnings({"deprecation", "rawtypes"})
public class CustomPersistence extends Persistence {

    public static EntityManagerFactory createEntityManagerFactory(String persistenceUnitName) {
        return CustomPersistence.createEntityManagerFactory(persistenceUnitName, null);
    }

    public static EntityManagerFactory createEntityManagerFactory(String persistenceUnitName, Map properties) {
        EntityManagerFactory emf = null;
        List<PersistenceProvider> providers = getProviders();
        PersistenceProvider defaultProvider = null;
        for (PersistenceProvider provider : providers) {
            if (provider instanceof HibernatePersistence) {
                defaultProvider = provider;
                continue;
            }
            emf = provider.createEntityManagerFactory(persistenceUnitName, properties);
            if (emf != null) {
                break;
            }
        }
        if (emf == null && defaultProvider != null)
            emf = defaultProvider.createEntityManagerFactory( persistenceUnitName, properties );
        if ( emf == null ) {
            throw new PersistenceException( "No Persistence provider for EntityManager named " + persistenceUnitName );
        }
        return emf;
    }

    protected static List<PersistenceProvider> getProviders() {
        return PersistenceProviderResolverHolder
                .getPersistenceProviderResolver()
                .getPersistenceProviders();
    }

}

Я протестировал этот код, и кажется, что он достаточно хорош для решения проблемы. В вашем коде вам просто нужно заменить класс Persistence на этот CustomPersistence. Надеюсь, это поможет.

person Shaka Shadows    schedule 27.05.2014
comment
Шака, да, обычно я использую его с Spring, но в этом случае я использовал только JPA и, получив предупреждение, хотел убедиться, что причина предупреждения не в моей ошибке в конфигурации. В любом случае, спасибо. - person Ashot Karakhanyan; 28.05.2014
comment
Ответ отредактирован. Я разобрался со всем эскизом. Я надеюсь, что это действительно поможет вам. - person Shaka Shadows; 28.05.2014
comment
См. также: hibernate.atlassian.net/browse/HHH-9141 (исправлено в версии 5.0). .0 бета1). - person Dave Jarvis; 20.06.2016

Следуя совету в предупреждении об устаревании, я обнаружил, что можно преодолеть эту проблему с помощью относительно аккуратного создания bean-компонента Spring для Entity Manager Factory.

Начиная здесь:

WARN: HHH015016: Encountered a deprecated javax.persistence.spi.PersistenceProvider [org.hibernate.ejb.HibernatePersistence]; use [org.hibernate.jpa.HibernatePersistenceProvider] instead.

Мы можем увидеть путь для получения класса, совместимого с javax.persistence.EntityManagerFactory, из Javadocs HibernatePersistenceProvider. Сначала вам нужен экземпляр HibernatePersistenceProvider, затем вызывается метод createEntityManagerFactory. Вот проводка Spring Bean, которая позволяет избежать предупреждения об устаревании:

<bean id="persistenceProvider" class="org.hibernate.jpa.HibernatePersistenceProvider">
</bean>
<bean id="emf" factory-bean="persistenceProvider" factory-method="createEntityManagerFactory">
   <constructor-arg value="testpersistence"/>
   <constructor-arg><map/></constructor-arg>
</bean>

Существует Здесь поток Stackoverflow, показывающий зависимости maven.

person antonycc    schedule 04.12.2014

Похоже, проблема была зарегистрирована как ошибка в спящем режиме и исправлена ​​для версии 5.0.0.Beta1, см. https://hibernate.atlassian.net/browse/HHH-9141

По крайней мере, у меня была та же проблема, и изменение зависимости на эту версию заставило мои предупреждения исчезнуть:

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-entitymanager</artifactId>
    <version>5.0.0.Beta1</version>
</dependency>
person stephanmunich    schedule 01.05.2015