- 使用自定义数据源而非spring数据源
如果你用JDBC数据连接, 又想让spring来管理事务, 那个你的连接需要用
org.springframework.jdbc.datasource.DataSourceUtils 来获得,例如:
Connection conn = DataSourceUtils.getConnection(dataSource);
并且要声明事务管理类
<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>
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
当你用自定义的DBUtil获取数据库连接时, spring不能干预事务, 自然也就无法回滚了。
2.自定义事务管理bean处理
package com.xxx.test.dao;
import ...
/**
* @author :aoyeye
* @date :Created in 2019/7/1 18:24
* spring默认事务管理bean name
* 继承AbstractTransactionalJUnit4SpringContextTests进行快速回滚,默认全部回滚
*/
@RunWith(SpringJUnit4ClassRunner.class)
@WebAppConfiguration
@SpringBootTest(classes = StartApplication.class)
@Transactional(transactionManager = "transactionManager")
public class MapperTest extends AbstractTransactionalJUnit4SpringContextTests {
//默认事务开启
@Test
public void test() {
...
}
@Test
@Rollback(value = false)//关闭事务
public void testRollBack() {
...
}
}
网友评论