Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/spring/14.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用Spring@Transactional管理Hibernate事务_Spring_Hibernate_Transactional - Fatal编程技术网

使用Spring@Transactional管理Hibernate事务

使用Spring@Transactional管理Hibernate事务,spring,hibernate,transactional,Spring,Hibernate,Transactional,我面临Spring3和Hibernate4的问题。 我想使用@Transactional来管理hibernate事务。我的JUnit测试使用HSQDB。但是在Tomcat上部署时,会发生异常 我尝试了许多配置,与单元测试一起使用的配置包括删除会话工厂配置中的hibernate.current\u session\u context\u类属性。然后在服务器模式下,发生以下异常: org.hibernate.HibernateException: No Session found for curre

我面临Spring3和Hibernate4的问题。 我想使用@Transactional来管理hibernate事务。我的JUnit测试使用HSQDB。但是在Tomcat上部署时,会发生异常

我尝试了许多配置,与单元测试一起使用的配置包括删除会话工厂配置中的hibernate.current\u session\u context\u类属性。然后在服务器模式下,发生以下异常:

org.hibernate.HibernateException: No Session found for current thread
at org.springframework.orm.hibernate4.SpringSessionContext.currentSession(SpringSessionContext.java:97)
at org.hibernate.internal.SessionFactoryImpl.getCurrentSession(SessionFactoryImpl.java:990)
at myproject.dao.impl.UserDaoImpl.create(UserDaoImpl.java:37)
当我将hibernate.current\u session\u context\u类配置为值“thread”时,异常是:

org.hibernate.HibernateException: save is not valid without active transaction
at org.hibernate.context.internal.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadLocalSessionContext.java:348)
at com.sun.proxy.$Proxy25.save(Unknown Source)
at myproject.dao.impl.UserDaoImpl.create(UserDaoImpl.java:39)
以下是我的配置:

<beans>
<context:annotation-config />
<tx:annotation-driven transaction-manager="transactionManager"/>
<jee:jndi-lookup id="dataSource" jndi-name="jdbc/MyDataSource"/>

<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="packagesToScan">
        <list>
            <value>myproject.dao.entity</value>
        </list>
    </property>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.connection.pool_size">1</prop>
            <prop key="hibernate.current_session_context_class">thread</prop>
            <prop key="hibernate.hbm2ddl.auto">update</prop>
        </props>
    </property>
</bean>

<bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory" />
</bean>
</beans>

myproject.dao.entity
org.hibernate.dialogue.mysqldialogue
真的
1.
线
更新

只需使用HibernateTemplate,因为它会自动执行事务管理。配置事务并不令人头痛

您在哪里定义事务注释,单元测试如何运行?使用Spring的测试助手类?搜索“openSessionInViewFilter”,您的单元测试可以工作,因为它们可以打开和关闭自己的会话。您可能还没有告诉您的web应用程序它需要这样做;因此,您的事务没有一个会话来运行w/in。我会提供更多的细节,但我必须暂时离开。我稍后会再问这个问题。非常感谢你们,伙计,它起作用了!!!欢迎来到StackOverflow。这是一个很好的开始,但远未完成。尽量让你的答案更加可靠,包括步骤和详细描述。那我很乐意投票给你一个好答案。