我正在尝试设置事务,但没有成功。 这里是我的代码:如何使用myBatis和Spring设置事务
<tx:annotation-driven transaction-manager="transactionManager" />
<bean id="dataSource" class="org.apache.ibatis.datasource.pooled.PooledDataSource">
.......
<property name="defaultAutoCommit" value="false" />
</bean>
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="configLocation" value="classpath:mybatis-configuration.xml" />
<property name="dataSource" ref="dataSource" />
</bean>
@Transactional
private void prcessTransaction(...) {
delete(...);
//insert:
for(Item item: itemList){
insert(item)
}
}
<delete id="delete" parameterType="map">
delete from .....
</delete>
<insert id="insert" parameterType="Item">
insert into ....
</insert>
它看起来像prcessTransaction方法不仅是交易,但多套成交。
我使用Spring 3.0.5,3.0.4的MyBatis,MyBatis的弹簧-1.0.1,Tomcat的7.0.19,甲骨文11.1.0.6.0
感谢您的帮助。
你在调用'getSqlMapClientTemplate'(Spring API)还是使用iBATIS API发出iBATIS调用? – atrain
我正在使用iBatis调用。 – user802293
您的数据库是否支持交易? – kurochenko