在 MyBatis 中,处理事务可以通过编程式事务管理或者声明式事务管理来实现。这里我们将分别介绍这两种方法。
编程式事务管理是通过编写代码来管理事务的开始、提交和回滚。在 MyBatis 中,你可以使用 SqlSession
对象来实现编程式事务管理。以下是一个简单的示例:
public class BaseDao {
private SqlSessionFactory sqlSessionFactory;
public BaseDao(SqlSessionFactory sqlSessionFactory) {
this.sqlSessionFactory = sqlSessionFactory;
}
public void saveData(Object data) {
SqlSession sqlSession = null;
try {
// 开启事务
sqlSession = sqlSessionFactory.openSession();
sqlSession.insert("YourMapperNamespace.saveData", data);
// 提交事务
sqlSession.commit();
} catch (Exception e) {
// 回滚事务
if (sqlSession != null) {
sqlSession.rollback();
}
throw new RuntimeException("Error saving data", e);
} finally {
// 关闭 SqlSession
if (sqlSession != null) {
sqlSession.close();
}
}
}
}
声明式事务管理是通过配置文件或注解来管理事务的开始、提交和回滚。在 Spring 框架中,你可以使用 @Transactional
注解来实现声明式事务管理。首先,需要在 Spring 配置文件中配置事务管理器:
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
<tx:annotation-driven transaction-manager="transactionManager" />
然后,在你的 BaseDao 层的方法上添加 @Transactional
注解:
import org.springframework.transaction.annotation.Transactional;
public class BaseDao {
@Autowired
private YourMapper yourMapper;
@Transactional
public void saveData(Object data) {
yourMapper.saveData(data);
}
}
这样,当 saveData
方法执行时,Spring 会自动为你管理事务的开始、提交和回滚。如果方法执行过程中发生异常,事务将回滚;否则,事务将提交。