配置成这样就可以了。 <!-- 声明式事务 -->
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"/>
</bean>
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<!-- 根据实际需要对指定方法进行事务参数的指定 -->
<tx:method name="*" isolation="READ_COMMITTED"/>
<tx:method name="find*" read-only="true"/>
</tx:attributes>
</tx:advice>
<aop:config>
<aop:advisor advice-ref="txAdvice" pointcut="execution(* com.wlzx.service.*.*(..))"/>
</aop:config>
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"/>
</bean>
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<!-- 根据实际需要对指定方法进行事务参数的指定 -->
<tx:method name="*" isolation="READ_COMMITTED"/>
<tx:method name="find*" read-only="true"/>
</tx:attributes>
</tx:advice>
<aop:config>
<aop:advisor advice-ref="txAdvice" pointcut="execution(* com.wlzx.service.*.*(..))"/>
</aop:config>
如果使用注解的话,有没有什么好的方法呢?
因为我们系统已经弄好了,方法名不好统一了已经
但是我发现使用<tx:annotation-driven transaction-manager="txManager"/>的话heibernate的事务不起作用
如果使用<tx:annotation-driven transaction-manager="hibernateTxManager"/>则ibatis的事务不起作用
使用注解的话在applicationContext.xml里面应该怎么配置呢?
但是我发现使用<tx:annotation-driven transaction-manager="txManager"/>的话heibernate的事务不起作用
如果使用<tx:annotation-driven transaction-manager="hibernateTxManager"/>则ibatis的事务不起作用
http://stamen.iteye.com/blog/1441858
序 号 混合数据访问技术框架 事务管理器
1 Hibernate+ Spring JDBC或iBatis org.springframework.orm.hibernate3.HibernateTransactionManager
2 JPA+Spring JDBC或iBatis org.springframework.orm.jpa.JpaTransactionManager
3 JDO+Spring JDBC或iBatis org.springframework.orm.jdo.JdoTransactionManager
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
"http://www.springframework.org/dtd/spring-beans.dtd">
<beans> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"/>
<property name="url" value="jdbc:oracle:thin:@192.168.77.176:1521:数据库"/>
<property name="username" value="用户"/>
<property name="password" value="密码"/>
</bean>
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>classpath:SqlMapConfig.properties</value>
</list>
</property>
</bean>
<bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
<property name="configLocation" value="classpath:SqlMapConfig.xml"/>
<property name="dataSource" ref="dataSource" />
</bean>
<bean id="testDAO" class="dao.TestDAO">
<property name="sqlMapClient" ref="sqlMapClient" />
</bean> <bean name="testService" class="service.TestService">
<property name="testDAO" ref="testDAO"/>
</bean>
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<bean id="transactionInterceptor" class="org.springframework.transaction.interceptor.TransactionInterceptor">
<property name="transactionManager" ref="transactionManager" />
<property name="transactionAttributes">
<props>
<prop key="*">PROPAGATION_REQUIRED,-Exception</prop>
<prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>
<prop key="query*">PROPAGATION_REQUIRED,readOnly</prop>
<prop key="get*">PROPAGATION_REQUIRED,readOnly</prop>
</props>
</property>
</bean>
<bean id="beanProxy" class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
<property name="beanNames">
<list>
<value>testService</value>
</list>
</property>
<property name="interceptorNames">
<list>
<value>transactionInterceptor</value>
</list>
</property>
</bean></beans>