配置成这样就可以了。 <!-- 声明式事务 -->
<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>

解决方案 »

  1.   

    一般事务是放在service层的,对于持久层,用ibatis还是hibernate,对spring来说,都是透明的,就像2楼的配置那样。当然也可以更细化一点,用注解在需要加事务的地方打上标记。
      

  2.   


    如果使用注解的话,有没有什么好的方法呢?
    因为我们系统已经弄好了,方法名不好统一了已经
    但是我发现使用<tx:annotation-driven transaction-manager="txManager"/>的话heibernate的事务不起作用
    如果使用<tx:annotation-driven transaction-manager="hibernateTxManager"/>则ibatis的事务不起作用
      

  3.   


    使用注解的话在applicationContext.xml里面应该怎么配置呢?
    但是我发现使用<tx:annotation-driven transaction-manager="txManager"/>的话heibernate的事务不起作用
    如果使用<tx:annotation-driven transaction-manager="hibernateTxManager"/>则ibatis的事务不起作用
      

  4.   

    使用hibernate来控制拦截 当然你也可以手动控制connection
      

  5.   

    我来转载个文章吧,楼主看看有没帮助
    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 
      

  6.   


    <?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>