我正在使用spring 3.0.3.RELEASE以及在Apache Tomcat 6.0.29中使用JDK 1.6.0_21运行的mybatis-3.0.2和mybatis-spring-1.0.0。
我创建了我的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");
}
}
}
答案 0 :(得分:2)
交易配置是围绕itemDao吗?所以每个itemDAO.delete调用都是一个单独的事务。因此,如果找到第一个id,则会在一个txn中删除它。对于第二个它不会发现,异常被抛出txn - 没有回滚。
听起来你需要在deleteItem方法周围设置txn。
答案 1 :(得分:0)
注意每个语句后提交的数据源的Tomcats自动提交设置。这对我来说听起来有点像。我曾经遇到过这个问题,而不是很有趣......