usando a propriedade current_session_context_class hibernate 3 hibernate 4

Eu tenho um aplicativo com Spring e Hibernate3 funcionando bem em produção. A seguir está a configuração da fábrica de sessões no applicationContext.xml do Spring

       <bean id="sessionFactory"
    class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="mappingDirectoryLocations">
        <list>
            <value>classpath:/hibernate</value>
        </list>
    </property>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect
            </prop>
            <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.max_fetch_depth">2</prop>
            <prop key="hibernate.autocommit">false</prop>
            <prop key="hibernate.current_session_context_class ">thread</prop>
                            <prop key="hibernate.generate_statistics">true</prop>
            <prop key="hibernate.jdbc.batch_size">20</prop>
        </props>
    </property>
</bean>

<bean id="txManager"
    class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory" />
</bean>
<!-- the transactional advice (what 'happens'; see the <aop:advisor/> bean 
    below) -->
<tx:advice id="txAdvice" transaction-manager="txManager">
    <!-- the transactional semantics... -->
    <tx:attributes>
        <tx:method name="*" propagation="REQUIRED" />
        <tx:method name="get*" propagation="SUPPORTS" read-only="true" />
        <tx:method name="count*" propagation="SUPPORTS" read-only="true" />
        <tx:method name="validate*" propagation="SUPPORTS"
            read-only="true" />
        <tx:method name="find*" propagation="SUPPORTS" read-only="true" />
        <tx:method name="login" propagation="SUPPORTS" read-only="true" />
    </tx:attributes>
</tx:advice>

<!-- ensure that the above transactional advice runs for any execution of 
    an operation defined by the service interfaces -->
<aop:config>
    <aop:pointcut id="projectServiceOperation"
        expression="execution(* com.service.project.IProjectService.*(..))" />
    <aop:advisor advice-ref="txAdvice" pointcut-ref="projectServiceOperation" />
</aop:config>

Está funcionando bem em produção.

Agora, para outro projeto, estamos migrando para o Hibernate4. nós copiamos sobre a mesma configuração, exceto usando SessionFactory, TransacionManager, etc. do Hierrnate 4 do pacote org.springframework.orm.hibernate4. *. No entanto, começou a dar exceção dizendo "Salvar não é válido sem transação ativa". Depois de procurar um pouco muitas pessoas pareciam ter enfrentado os problemas e várias pessoas sugeriram não usar

        <prop key="hibernate.current_session_context_class ">thread</prop>

propriedade e funcionou. Também funcionou para mim. Todas as poucas informações que consegui coletar nos posts que tem algo a ver com sessões contextuais e estratégias de thread interferem na estratégia de gerenciamento de sessões do Spring. Mas não onde eu poderia encontrar qualquer resposta concreta. Além disso, por que funcionava com o Hibernate3 e não com o Hibernate4? Qual é a diferença e o que mudou? Todas as outras configurações são iguais. Eu não estou usando o @Transactional, mas o caminho XML da velha escola.

    Can somebody point me to clear explaination for this behavioural difference in Hibernate3 and Hibernate4?  

questionAnswers(1)

yourAnswerToTheQuestion