2016-07-04 4 views
2

Я пытаюсь настроить весеннюю версию 4.3.1 с hibernate 5, но у меня возникла ошибка при попытке создать фабрику управления сущностями.configure spring4 with hibernate5

Моя зимуют версия 5.0.9.Final» спящий режим валидатор версия "5.2.4.Final"

Мои зависимости

  • зимуют-жильный 5.0.9.Final
  • зимуют-EntityManager 5.0.9.Final
  • Hibernate-EHCache 5.0.9
  • Hibernate-валидатор 5.2.4.Final
  • гибернации-JPA-2,1-апи 1.0.0.Final
  • валидация-апи 1.0.0.GA

это моя конфигурация:

@Configuration 
@EnableTransactionManagement 
public class JpaConfiguration { 

@Value("classpath:hibernate.properties") 
private Properties jpaProperties; 

@Resource(name = "dataSource") 
private DataSource dataSource; 

/** 
* Enable exception translation for beans annotated with @Repository 
*/ 
@Bean 
public PersistenceExceptionTranslationPostProcessor exceptionTranslation() { 
    return new PersistenceExceptionTranslationPostProcessor(); 
} 

/** 
* @see read http://www.springframework.org/docs/reference/transaction.html 
*/ 
@Bean 
public JpaTransactionManager transactionManager() { 
    return new JpaTransactionManager(); 
} 

/** 
* Build the entity manager with Hibernate as a provider. 
*/ 
@Bean 
public LocalContainerEntityManagerFactoryBean entityManagerFactory() { 
    LocalContainerEntityManagerFactoryBean emf = new LocalContainerEntityManagerFactoryBean(); 
    emf.setDataSource(dataSource); 
    // We set the persistenceXmlLocation to a different name to make it work on JBoss. 
    emf.setPersistenceXmlLocation("classpath:META-INF/spring-persistence.xml"); 
    emf.setPersistenceUnitName("myPU"); 
    emf.setJpaVendorAdapter(new HibernateJpaVendorAdapter()); 
    emf.setJpaProperties(jpaProperties); 
    emf.setJpaDialect(new HibernateJpaDialect()); 
    return emf; 
} 

@Bean 
public SessionFactory sessionFactory(HibernateEntityManagerFactory entityManagerFactory) { 
    return entityManagerFactory.getSessionFactory(); 
} 
} 

и я получил ошибку:

Exception in thread "main" org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in com.xxx.configuration.JpaConfiguration: Invocation of init method failed; nested exception is java.lang.AbstractMethodError 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1578) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:545) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:482) 
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306) 
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197) 
    at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:1076) 
    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:851) 
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:541) 
    at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139) 
    at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:83) 
    at com.xxx.Boot$.main(Boot.scala:44) 
    at com.xxx.Boot.main(Boot.scala) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:144) 
Caused by: java.lang.AbstractMethodError 
    at org.hibernate.internal.SessionFactoryImpl.<init>(SessionFactoryImpl.java:278) 
    at org.hibernate.boot.internal.SessionFactoryBuilderImpl.build(SessionFactoryBuilderImpl.java:444) 
    at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:879) 
    at org.springframework.orm.jpa.vendor.SpringHibernateJpaPersistenceProvider.createContainerEntityManagerFactory(SpringHibernateJpaPersistenceProvider.java:60) 
    at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalContainerEntityManagerFactoryBean.java:338) 
    at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.buildNativeEntityManagerFactory(AbstractEntityManagerFactoryBean.java:373) 
    at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:362) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1637) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1574) 
    ... 18 more 

Но когда я меняю версию спящего режима с 5 на 4, все работает нормально.

Resolve:

Проблемы была с org.jadira.usertype» "usertype.core" и я получил несоответствие с спящей версией 4 и 5.

+0

Какая * точная * версия спящего режима ... Рядом с этим добавьте зависимости, которые вы используете. –

+2

Кажется типичной ошибкой, когда у вас есть микширование Hibernate 4 и Hibernate 5 банок на пути к классам. – Gimby

+0

моя версия спящего режима 5.0.9. Финальный и гибернативный валидатор 5.2.4.Final –

ответ

1

Проблемой был с org.jadira .usertype "" usertype.core ", и у меня есть несоответствие с версией 4 и 5 спящего режима в classpath