IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Hibernate Java Discussion :

probleme de session avec hibernate


Sujet :

Hibernate Java

  1. #1
    Membre régulier
    Inscrit en
    Mai 2002
    Messages
    219
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 219
    Points : 74
    Points
    74
    Par défaut probleme de session avec hibernate
    bonjour a tout , j ai un probleme de session avec hibernate
    org.hibernate.HibernateException: No Hibernate Session bound to thread, and configuration does not allow creation of non-transactional one here
    at org.springframework.orm.hibernate3.AbstractSessionFactoryBean$TransactionAwareInvocationHandler.invoke(AbstractSessionFactoryBean.java:299)
    at $Proxy0.getCurrentSession(Unknown Source)
    at retrieveByCriteria(AbstractHibernateDao.java:111)
    at retrieveByCriteria(AbstractHibernateDao.java:95)
    at retrieveEntriesByCriteria(HibernateEntryDao.java:81)
    at testRetrieveEntriesByCriteria(HibernateEntryDaoTest.java:90)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:585)
    at junit.framework.TestCase.runTest(TestCase.java:164)
    at junit.framework.TestCase.runBare(TestCase.java:130)
    at junit.framework.TestResult$1.protect(TestResult.java:110)
    at junit.framework.TestResult.runProtected(TestResult.java:128)
    at junit.framework.TestResult.run(TestResult.java:113)
    at junit.framework.TestCase.run(TestCase.java:120)
    at junit.framework.TestSuite.runTest(TestSuite.java:228)
    at junit.framework.TestSuite.run(TestSuite.java:223)
    at org.junit.internal.runners.OldTestClassRunner.run(OldTestClassRunner.java:35)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:46)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

    et voici mon code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
     
    package database;
     
    import java.io.File;
    import java.io.FileInputStream;
    import java.net.MalformedURLException;
    import java.util.List;
     
    import junit.framework.TestCase;
     
    import org.dbunit.IDatabaseTester;
    import org.dbunit.JdbcDatabaseTester;
    import org.dbunit.PropertiesBasedJdbcDatabaseTester;
    import org.dbunit.database.IDatabaseConnection;
    import org.dbunit.dataset.DataSetException;
    import org.dbunit.dataset.IDataSet;
    import org.dbunit.dataset.xml.FlatXmlDataSetBuilder;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
     
    import Entry;
    import EntrySearchCriteria;
     
    public class HibernateEntryDaoTest extends TestCase {
    	private IDatabaseTester databaseTester;
    	IEntryDao entryDao;
     
    	public HibernateEntryDaoTest(String name) throws Exception {
    		super(name);
    	}
     
    	protected void setUp() throws Exception {
    		ClassPathXmlApplicationContext ctx = new ClassPathXmlApplicationContext(
    		"spring-fbi-configTest.xml");
    entryDao = (IEntryDao) ctx.getBean("dao.entry");
     
    		System.setProperty(
    				PropertiesBasedJdbcDatabaseTester.DBUNIT_DRIVER_CLASS,
    				"org.hsqldb.jdbcDriver");
     
    		System.setProperty(
    				PropertiesBasedJdbcDatabaseTester.DBUNIT_CONNECTION_URL,
    				"jdbc:hsqldb:fbiBpsa");
    		System.setProperty(PropertiesBasedJdbcDatabaseTester.DBUNIT_USERNAME,
    				"SA");
    		System.setProperty(PropertiesBasedJdbcDatabaseTester.DBUNIT_PASSWORD,
    				"");
    		databaseTester = new PropertiesBasedJdbcDatabaseTester();
     
    		IDatabaseConnection connectionHsql = databaseTester.getConnection();
     
    		databaseTester.setDataSet(getDataSet());
    		// will call default setUpOperation
    		databaseTester.onSetup();
     
    	}
     
    	protected IDataSet getDataSet() throws Exception {
    		return new FlatXmlDataSetBuilder().build(new FileInputStream(
    				("src\\test\\resources\\full.xml")));
    	}
     
    	public void testRetrieveEntriesByCriteria() throws MalformedURLException,
    			DataSetException {
    		EntrySearchCriteria searchCriteria = new EntrySearchCriteria();
     
    		List<Entry> entriesListResult = entryDao
    				.retrieveEntriesByCriteria(searchCriteria);
    		assertEquals(entriesListResult.size(),29);
    		IDataSet expectedDataSet = new FlatXmlDataSetBuilder().build(new File(
    				"expectedDataSet.xml"));
     
    	}
     
    	protected void tearDown() throws Exception {
    		// will call default tearDownOperation
    		databaseTester.onTearDown();
    	}
     
    }
    et mon fichier spring
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    <?xml version="1.0" encoding="UTF-8"?>
    
    <beans
    	xmlns="http://www.springframework.org/schema/beans"
    	xmlns:aop="http://www.springframework.org/schema/aop"
    	xmlns:jee="http://www.springframework.org/schema/jee"
    	xmlns:tx="http://www.springframework.org/schema/tx"
    	xmlns:util="http://www.springframework.org/schema/util"
    	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    	xsi:schemaLocation="
    		http://www.springframework.org/schema/aop	http://www.springframework.org/schema/aop/spring-aop-2.0.xsd
    		http://www.springframework.org/schema/beans
    		http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
    		http://www.springframework.org/schema/jee   http://www.springframework.org/schema/jee/spring-jee-2.0.xsd
    		http://www.springframework.org/schema/tx	http://www.springframework.org/schema/tx/spring-tx-2.0.xsd
    		http://www.springframework.org/schema/util  http://www.springframework.org/schema/util/spring-util-2.0.xsd
    	"
    >
    	<!--//////////////////////////////////////////////////////////////////////////-->
    	<!--////////////////////////////// Placeholders //////////////////////////////-->
    	<!--//////////////////////////////////////////////////////////////////////////-->
    	
    	<bean
    		class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"
    		id="propertyConfigurer"
    	>
    		<property name="location" value="spring-fbiTest.properties"/>
    	</bean>
    
    	<!--//////////////////////////////////////////////////////////////////////////-->
    	<!--////////////////////////// Data Access Objects ///////////////////////////-->
    	<!--//////////////////////////////////////////////////////////////////////////-->
    
    
    
    	<bean
    		class="org.springframework.jdbc.datasource.DriverManagerDataSource"
    		id="ds.fbi"
    	>
    		<property name="driverClassName" value="${ds.fbi.driver}"/>
    		<property name="password" value="${ds.fbi.password}"/>
    		<property name="url" value="${ds.fbi.url}"/>
    		<property name="username" value="${ds.fbi.username}"/>
    	</bean>
    	
     	<bean
    		class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"
    		destroy-method="destroy"
    		id="sf.fbi"
    	>
    		<property name="dataSource" ref="${sf.fbi.datasource}"/>
    		<property name="hibernateProperties">
    			<bean class="org.springframework.beans.factory.config.PropertiesFactoryBean">
    				<property name="properties">
    					<props>
    						<prop key="hibernate.c3p0.max_size">${hibernate.c3p0.max_size}</prop>
    						<prop key="hibernate.c3p0.min_size">${hibernate.c3p0.min_size}</prop>
    						<prop key="hibernate.c3p0.timeout">${hibernate.c3p0.timeout}</prop>
    						
    						<prop key="hibernate.cache.provider_class">${hibernate.cache.provider_class}</prop>
    						<prop key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop>
    						<prop key="hibernate.cache.use_second_level_cache">${hibernate.cache.use_second_level_cache}</prop>
    						
    						<prop key="hibernate.current_session_context_class">thread</prop>
    						<prop key="hibernate.dialect">${sf.fbi.dialect}</prop>
    						<prop key="hibernate.hbm2ddl.auto">${fbi.autocreate}</prop>
    						<prop key="hibernate.jdbc.batch_size">20</prop>
    						<prop key="hibernate.show_sql">false</prop>
    					</props>
    				</property>
    			</bean>
    		</property>
    		
    		<property name="mappingResources">
    			<list>
    				<value>hibernate/Entry.hbm.xml</value>
    			</list>
     		</property>
    	</bean>
    
    	<bean
    		class="org.springframework.orm.hibernate3.HibernateTransactionManager"
    		id="tm.fbi"
    	>
    		<property name="sessionFactory" ref="sf.fbi"/>
    	</bean>
    
    	<tx:advice
    		id="ta.fbi"
    		transaction-manager="tm.fbi"
    	>
    		<tx:attributes>
    			<tx:method name="create"/>
    			<tx:method name="createOrUpdate"/>
    			<tx:method name="delete"/>
    			<tx:method name="retrieve*"/>
    			<tx:method name="retrieveEntriesByCriteria"/>
    			<tx:method name="test*"/>
    			<tx:method name="update"/>
    			<tx:method name="clearPrices"/>
    		</tx:attributes>
    	</tx:advice>
    
    	<bean
    		abstract="true"
    		class="AbstractHibernateDao"
    		id="abstractHibernateDao.fbi"
    	>
    		<property name="sessionFactory" ref="sf.fbi"/>
    	</bean>
    	
    	
    	
    	<bean
    		class="HibernateEntryDao"
        	id="dao.entry"
    		parent="abstractHibernateDao.fbi"
    	/>
    </beans>
    pourtant j ai bel et bien une transaction associe a mon dao
    voir les truc en gras.

    Est ce qu il y a une personne qui peut m aide merci

  2. #2
    Membre régulier
    Inscrit en
    Mai 2002
    Messages
    219
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 219
    Points : 74
    Points
    74
    Par défaut
    Ok , j'ai changé de stratégie.
    maintenant , j’utilise TransactionProxyFactoryBean
    mais le résultat est le même

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
     
    <?xml version="1.0" encoding="UTF-8"?>
     
    <beans xmlns="http://www.springframework.org/schema/beans"
    	xmlns:aop="http://www.springframework.org/schema/aop" xmlns:jee="http://www.springframework.org/schema/jee"
    	xmlns:tx="http://www.springframework.org/schema/tx" xmlns:util="http://www.springframework.org/schema/util"
    	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    	xsi:schemaLocation="
    		http://www.springframework.org/schema/aop	http://www.springframework.org/schema/aop/spring-aop-2.0.xsd
    		http://www.springframework.org/schema/beans
    		http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
    		http://www.springframework.org/schema/jee   http://www.springframework.org/schema/jee/spring-jee-2.0.xsd
    		http://www.springframework.org/schema/tx	http://www.springframework.org/schema/tx/spring-tx-2.0.xsd
    		http://www.springframework.org/schema/util  http://www.springframework.org/schema/util/spring-util-2.0.xsd
    	">
    	<!--
    		//////////////////////////////////////////////////////////////////////////
    	-->
    	<!--
    		////////////////////////////// Placeholders
    		//////////////////////////////
    	-->
    	<!--
    		//////////////////////////////////////////////////////////////////////////
    	-->
     
    	<bean
    		class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"
    		id="propertyConfigurer">
    		<property name="location" value="spring-fbiTest.properties" />
    	</bean>
     
    	<!--
    		//////////////////////////////////////////////////////////////////////////
    	-->
    	<!--
    		////////////////////////// Data Access Objects
    		///////////////////////////
    	-->
    	<!--
    		//////////////////////////////////////////////////////////////////////////
    	-->
     
     
     
    	<bean class="org.springframework.jdbc.datasource.DriverManagerDataSource"
    		id="ds.fbi">
    		<property name="driverClassName" value="${ds.fbi.driver}" />
    		<property name="password" value="${ds.fbi.password}" />
    		<property name="url" value="${ds.fbi.url}" />
    		<property name="username" value="${ds.fbi.username}" />
    	</bean>
     
    	<bean class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"
    		destroy-method="destroy" id="sf.fbi">
     
    		<property name="dataSource" ref="${sf.fbi.datasource}" />
    		<property name="hibernateProperties">
    			<bean
    				class="org.springframework.beans.factory.config.PropertiesFactoryBean">
    				<property name="properties">
    					<props>
    						<prop key="hibernate.cache.provider_class">${hibernate.cache.provider_class}</prop>
    						<prop key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop>
    						<prop key="hibernate.cache.use_second_level_cache">${hibernate.cache.use_second_level_cache}</prop>
    						<prop key="hibernate.dialect">${sf.fbi.dialect}</prop>
    						<prop key="hibernate.hbm2ddl.auto">${fbi.autocreate}</prop>
    						<prop key="hibernate.jdbc.batch_size">20</prop>
    						<prop key="hibernate.show_sql">false</prop>
    						<prop key="hibernate.transaction.factory_class">org.hibernate.transaction.JDBCTransactionFactory
    						</prop>
    					</props>
    				</property>
    			</bean>
    		</property>
     
    		<property name="mappingResources">
    			<list>
    				<value>hibernate/ChangeLog.hbm.xml</value>
    				<value>hibernate/Fees.hbm.xml</value>
    				<value>hibernate/Entry.hbm.xml</value>
    				<value>hibernate/Correspondents.hbm.xml</value>
    				<value>hibernate/ResidenceTaxes.hbm.xml</value>
    				<value>hibernate/CorrespondentFees.hbm.xml</value>
    				<value>hibernate/FeeTypes.hbm.xml</value>
    				<value>hibernate/Departments.hbm.xml</value>
    				<value>hibernate/Taxes.hbm.xml</value>
    				<value>hibernate/CertificateEntry.hbm.xml</value>
    			</list>
    		</property>
    	</bean>
     
    	<bean class="org.springframework.orm.hibernate3.HibernateTransactionManager"
    		id="tm.fbi">
    		<property name="sessionFactory" ref="sf.fbi" />
    	</bean>
    	<bean id="transactionalStudentDao"
    		class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
    		<property name="transactionManager">
    			<ref bean="tm.fbi" />
    		</property>
    		<property name="target">
    			<bean class="HibernateEntryDao">
    				<property name="sessionFactory">
    					<ref local="sf.fbi" />
    				</property>
    			</bean>
    		</property>
    		<property name="transactionAttributes">
    			<props>
    				<prop key="*">PROPAGATION_REQUIRED</prop>
    			</props>
    		</property>
    	</bean>
     
    	<bean abstract="true" class="AbstractHibernateDao"
    		id="abstractHibernateDao.fbi">
    		<property name="sessionFactory" ref="sf.fbi" />
    	</bean>
     
     
    	<bean class="HibernateEntryDao" id="dao.entry"
    		parent="abstractHibernateDao.fbi" />
     
     
    </beans>

Discussions similaires

  1. Probleme de mapping avec Hibernate
    Par kodo dans le forum Hibernate
    Réponses: 10
    Dernier message: 31/07/2006, 09h33
  2. [strust] probleme de session avec IE
    Par pouss dans le forum Struts 1
    Réponses: 5
    Dernier message: 27/04/2006, 17h37
  3. Réponses: 13
    Dernier message: 31/03/2006, 16h22
  4. [Sécurité] probleme de session avec aol
    Par jexl dans le forum Langage
    Réponses: 5
    Dernier message: 21/02/2006, 16h59
  5. Probleme de sessions avec un hébergeur
    Par totoranky dans le forum Langage
    Réponses: 3
    Dernier message: 20/10/2005, 02h36

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo