繁体   English   中英

Spring声明式事务管理不起作用

[英]Spring declarative transaction management not working

我正在使用Spring 3.0.3.RELEASE以及mybatis-3.0.2和mybatis-spring-1.0.0,它们在带有JDK 1.6.0_21的Apache Tomcat 6.0.29中运行。

我创建了我的DAO类和Service类,并按照声明式事务控制进行了定义-

<tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <tx:method name="*" propagation="REQUIRED" />
        </tx:attributes>
    </tx:advice>
    <aop:config>
        <aop:pointcut id="dtxops"
            expression="execution(* com.project.service.*.*(..))" />
        <aop:advisor advice-ref="txAdvice" pointcut-ref="dtxops" />
    </aop:config>
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource">
            <ref bean="dataSource" />
        </property>
    </bean>

此方法在使用ItemDAO的com.project.service.ItemDAOServiceImpl类中。 SystemException是RunTimeException。 我传递了2个要删除的ID,系统中存在一个ID,其他ID不存在。 由于一个ID不存在,因此出现SystemException,但是当我检查数据库时,另一个ID被删除而不是回滚。

public void deleteItem(List<Integer> itemIds) {
        for (int itemId : itemIds) {
            try {
                int result = itemDAO.delete(itemId);
                if (result != 1) {
                    throw new SystemException(
                            "Failed to delete item");
                }
            } catch (DataAccessException dae) {
                log.error("Failed to delete item", dae);
                throw new SystemException("Failed to delete items");
            }
        }
    }

事务配置在itemDao周围吗? 因此,每个itemDAO.delete调用都是一个单独的事务。 因此,如果找到第一个ID,则会在一个txn中将其删除。 对于第二个它不会发现,该异常被抛出到txn之外-没有回滚。

听起来您需要在deleteItem方法周围设置txn。

注意在每个语句之后提交的数据源的Tomcats自动提交设置。 对我来说听起来有点像。 我曾经遇到过这个问题,不好玩...

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM