使用hibernate5

时间:2016-07-04 13:31:12

标签: java spring spring-data-jpa hibernate-5.x abstractmethoderror

我尝试使用hibernate 5配置spring版本4.3.1但是在尝试创建实体管理器工厂时遇到错误。

我的hibernate版本5.0.9.Final" hibernate验证器版本" 5.2.4.Final"

我的依赖

  • hibernate-core 5.0.9.Final
  • hibernate-entitymanager 5.0.9.Final
  • hibernate-ehcache 5.0.9
  • hibernate-validator 5.2.4.Final
  • hibernate-jpa-2.1-api 1.0.0.Final
  • validation-api 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时,一切正常。

消退:

问题在于org.jadira.usertype&#34; &#34; usertype.core&#34;我与hibernate版本4和5不匹配。

1 个答案:

答案 0 :(得分:1)

问题在于org.jadira.usertype&#34; &#34; usertype.core&#34;我在类路径

中与hibernate版本4和5不匹配