2016-06-04 30 views
5

Ho guardato in giro messaggi simili con SessionFactory e Mancanti Main(). Il mio problema non è legato a loro. Non sono sicuro se un barattolo sia una mancata corrispondenza. Sto cercando uno Spring4.2.6 campione con il codice Hibernate5.2 utilizzando JDK8 e ottenere questa eccezione:HibernateTemplate sta lanciando java.lang.NoSuchMethodError: org.hibernate.Session.getFlushMode() - Spring4.2.6, Hibernate5.2

Exception in thread "main" java.lang.NoSuchMethodError: org.hibernate.Session.getFlushMode()Lorg/hibernate/FlushMode; 
at org.springframework.orm.hibernate5.HibernateTemplate.checkWriteOperationAllowed(HibernateTemplate.java:1125) 
at org.springframework.orm.hibernate5.HibernateTemplate$12.doInHibernate(HibernateTemplate.java:619) 
at org.springframework.orm.hibernate5.HibernateTemplate$12.doInHibernate(HibernateTemplate.java:616) 
at org.springframework.orm.hibernate5.HibernateTemplate.doExecute(HibernateTemplate.java:341) 
at org.springframework.orm.hibernate5.HibernateTemplate.executeWithNativeSession(HibernateTemplate.java:309) 
at org.springframework.orm.hibernate5.HibernateTemplate.save(HibernateTemplate.java:616) 
at com.nougain.springtraining.hibernate.CustomerDAOImpl.save(CustomerDAOImpl.java:37) 
at com.nougain.springtraining.hibernate.Client_SpringHibernate.testSpringHibernate(Client_SpringHibernate.java:29) 
at com.nougain.springtraining.hibernate.Client_SpringHibernate.main(Client_SpringHibernate.java:12) 

Di seguito il file jar che sto usando:

<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/> 
<classpathentry kind="lib" path="C:/Java Stuff/spring-framework-4.2.6.RELEASE/libs/spring-beans-4.2.6.RELEASE.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/spring-framework-4.2.6.RELEASE/libs/spring-core-4.2.6.RELEASE.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/spring-framework-4.2.6.RELEASE/libs/spring-context-4.2.6.RELEASE.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/Apache Commons/commons-logging-1.2/commons-logging-1.2.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/spring-framework-4.2.6.RELEASE/libs/spring-expression-4.2.6.RELEASE.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/jars/javax.inject.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/spring-framework-4.2.6.RELEASE/libs/spring-test-4.2.6.RELEASE.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/spring-framework-4.2.6.RELEASE/libs/spring-jdbc-4.2.6.RELEASE.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/spring-framework-4.2.6.RELEASE/libs/spring-orm-4.2.6.RELEASE.jar"/> 
<classpathentry exported="true" kind="lib" path="C:/Java Stuff/hibernate-release-5.2.0.Final/lib/required/jboss-logging-3.3.0.Final.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/Oracle JDBC Driver/ojdbc7.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/junit-4.12/junit-4.12.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/junit-4.12/hamcrest-core-1.3.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/spring-framework-4.2.6.RELEASE/libs/spring-tx-4.2.6.RELEASE.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/jars/aopalliance-1.0.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/jars/aspectjweaver-1.8.9.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/spring-framework-4.2.6.RELEASE/libs/spring-aop-4.2.6.RELEASE.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/Apache Commons/commons-dbcp2-2.1.1/commons-dbcp2-2.1.1.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/Apache Commons/commons-pool2-2.4.2/commons-pool2-2.4.2.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/hibernate-release-5.2.0.Final/lib/required/hibernate-core-5.2.0.Final.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/hibernate-release-5.2.0.Final/lib/required/hibernate-jpa-2.1-api-1.0.0.Final.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/hibernate-release-5.2.0.Final/lib/required/geronimo-jta_1.1_spec-1.1.1.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/hibernate-release-5.2.0.Final/lib/required/dom4j-1.6.1.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/hibernate-release-5.2.0.Final/lib/required/hibernate-commons-annotations-5.0.1.Final.jar"/> 
<classpathentry kind="lib" path="C:/Java Stuff/hibernate-release-5.2.0.Final/lib/required/classmate-1.3.0.jar"/> 

codice DAOImpl snippet:

import org.springframework.stereotype.Component; 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.orm.hibernate5.HibernateTemplate; 

@Component("customerDAO") 
public class CustomerDAOImpl implements CustomerDAO { 
    @Autowired 
    private HibernateTemplate hibernateTemplate; 

    public CustomerDAOImpl() { 
     System.out.println("___Created CustomerDAOImpl() object"); 
    } 

    @Override 
    public void save(Customer c) { 
     hibernateTemplate.save(c); 
    } 
     ... 
} 

Il mio file di configurazione è simile a:

<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> 
    <property name="locations"> 
     <array> 
      <value>bin/connection.properties</value> 
     </array> 
    </property> 
</bean> 

<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"> 
    <property name="driverClassName" value="${driver_class_name}"/> 
    <property name="url" value="${url}"/> 
    <property name="username" value="${username}"/> 
    <property name="password" value="${password}"/> 
    <property name="initialSize" value="${initial_size}"/> 
    <property name="maxTotal" value="${max_size}"/> 
</bean> 

<bean class="org.springframework.orm.hibernate5.LocalSessionFactoryBean"> 
    <property name="dataSource" ref="dataSource" /> 
    <property name="hibernateProperties"> 
     <props> 
      <prop key="hibernate.show_sql">true</prop> 
      <prop key="hibernate.format_sql">true</prop> 
      <prop key="hibernate.use_sql_comments">true</prop> 
      <prop key="hibernate.transaction.factory_class"> 
       org.hibernate.transaction.JDBCTransactionFactory 
      </prop> 
      <prop key="hibernate.hbm2ddl.auto">create</prop> 
     </props> 
    </property> 
    <property name="mappingResources"> 
     <array> 
      <value>Customer.hbm.xml</value> 
     </array> 
    </property> 
</bean> 

Grazie per il vostro aiuto.

+0

La risposta pertinente è stata fornita qui: [http://stackoverflow.com/a/37613224/1035593](http://stackoverflow.com/a/37613224/1035593). – rikica

risposta

7

Non riesco ancora a far funzionare Spring 4.2.6 con Hibernate 5.2.0 (che è stato appena rilasciato qualche giorno fa), anche se l'errore che ho ottenuto è diverso. Sto ancora usando Hibernate 5.1.0 quindi.

Si noti che su Hibernate 5.1.0 sono necessari due contenitori: hibernate-core e hibernate-entitymanager.

[EDIT] Spring 4.2.6 elenca Hibernate 5.0.9 come dipendenza opzionale, quindi è probabile che dovresti rimanere fedele a quella versione, anche se 5.1.0 funziona correttamente per me.

Spring 4.2.6 probabilmente non è compatibile con Hibernate 5.2.0 poiché questa versione di hibernate ha apportato alcune grosse modifiche, unendo hibernate-core con hibernate-entitymanager e hibernate-java8.

+0

Grazie, Andre. Ho apportato poche modifiche al programma e ha funzionato con Hibernate 5.0.9 AS Well con 5.2.0. Non so cosa abbia fatto sparire il problema. Principali modifiche che ho fatto: \t \t 'Codice delle \t \t SessionFactory sessionFactory = hibernateTemplate.getSessionFactory(); \t \t Sessione sessione = sessionFactory.openSession(); \t \t Transaction txn = session.beginTransaction(); // <- La transazione è necessaria qui per inserire. Ma perché???? \t \t session.save (c); \t txn.commit(); – ludwig17

+0

Accettando questo come risposta con il mio commento datato 8 giugno 2016. – ludwig17

+0

Penso che il problema sia scomparso perché compilato con 5.2 collegato. Prova a compilare con 5.1 e utilizzare con 5.2, penso che non funzionerà. –

Problemi correlati