1 错误代码:
try{
ApplicationContext app = new ClassPathXmlApplicationContext("applicationContext.xml");
String[] beanNames = app.getBeanDefinitionNames();
factory = app.getBean(SqlSessionFactory.class, "factory");
session = factory.openSession(false);
Book book = new Book();
book.setId(36);
book.setName("fengshenbang");
book.setPosition("C:/");
bookmapper.addBook(book);
session.commit();
} catch(Exception e) {
System.out.println(e);
if (null != session) {
session.rollback();
System.out.println("事务回滚");
}
}
2 原因分析: 无法通过mybatis的factory.openSession(),session.commit()提交、回滚事务。原因:spring整合mybatis时,mapper是通过spring初始化并获取的,这时候mapper已经被spring管理起来了,而通过这种方式factory.openSession(),session.commit()获取的只是mabatis获取的事务,没有被spring管理起来,两者在各自的组件中运行,事务自动提交,即使回滚,mybatis也无法回滚spring管理的事务。
3 修改方法:
既然是通过spring管理的mapper和数据源,引入spring的事务管理即可。
3.1 配置事务管理器
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
3.2 代码中获取事务并设置提交、回滚条件
TransactionStatus status = null;
DataSourceTransactionManager txManager = null;
DefaultTransactionDefinition def = new DefaultTransactionDefinition();
def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRES_NEW);
txManager = app.getBean(DataSourceTransactionManager.class, "txManager");
status = txManager.getTransaction(def);
txManager.commit(status); or txManager.rollback(status);
使用spring整合mybatis时,通过spring加载的mapper操作怎么回滚
最新推荐文章于 2023-05-26 16:23:31 发布