[英]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.