春天@Transactional不起作用?

时间:2010-12-08 03:45:51

标签: java spring ibatis rollback

我目前正在构建一个应用程序使用spring作为框架。我想用spring测试批处理事务。这是我的代码:

public class SqlMapTestDao extends SqlMapClientDaoSupport implements TestDao {

public List<Test> getAllTest() {
    return getSqlMapClientTemplate().queryForList("getAllTest");
}

public Test getTest(int param) { 
    return (Test)getSqlMapClientTemplate().queryForObject("getTest" , param);
}

public void insertTest(Test test) {
    getSqlMapClientTemplate().insert("insertTest", test);
}

@Transactional(readOnly = false)
public void insertBatch(List<Test> batch) throws SQLException{      
    for(Test test : batch) {
        getSqlMapClientTemplate().insert("insertTest", test);
    }               
}   
}

我尝试插入与下面相同的主键。

@Autowired
private TestDao testDao;

@RequestMapping(value="/", method=RequestMethod.GET)
public String home(@ModelAttribute Account acc) {

    List<Test> test = new ArrayList<Test>();

    test.add(new Test(7, "ini empat"));
    test.add(new Test(1, "ini satu"));
    test.add(new Test(8, "ini lima"));      

    try {
        testDao.insertBatch(test);
    }catch (Exception e) {
        logger.error("Error", e.getStackTrace());
    }

    logger.info("Welcome Home");
    return "home";
}

当它以Id 1执行时,它将抛出错误,我希望所有查询都将回滚。但是7进入数据库。为什么它不能回滚?我哪里错了?

我使用ibatis和mysql作为数据库。

这里是xml配置:

<!-- Configures transaction management around @Transactional components -->
<tx:annotation-driven transaction-manager="transactionManager" />


<!-- Resource loader for jdbc configuration -->
<context:property-placeholder location="WEB-INF/jdbc.properties"/>

<!-- Local Apache Commons DBCP DataSource that refers to a combined database -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="${jdbc.driverClassName}"/>
    <property name="url" value="${jdbc.url}"/>
    <property name="username" value="${jdbc.username}"/>
    <property name="password" value="${jdbc.password}"/>
</bean>

<!-- Transaction manager for a single JDBC DataSource -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource"/>
</bean>

<!-- SqlMap setup for iBATIS Database Layer -->
<bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
    <property name="configLocation" value="WEB-INF/sql-map-config.xml"/>
    <property name="dataSource" ref="dataSource"/>
</bean>

<!-- testing purpose -->
<bean id="testDao" class="com.shop.cart.dao.ibatis.SqlMapTestDao">
    <property name="sqlMapClient" ref="sqlMapClient"/>
</bean>

2 个答案:

答案 0 :(得分:5)

可能是因为你的mysql表不是InnoDB类型,所以事务不能正常工作。

答案 1 :(得分:1)

您是否在Spring XML配置中定义了所有必需的元素?

<tx:annotation-driven transaction-manager="txManager"/>

<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <!-- (this dependency is defined somewhere else) -->
    <property name="dataSource" ref="dataSource"/>
</bean>

无论哪种方式,您都应该在此处发布Spring XML配置以获得其他诊断帮助。有关详细信息,请参阅Transaction Management