温馨提示×

MyBatis BaseDao层如何处理事务

小樊
82
2024-09-10 03:04:24
栏目: 编程语言

在 MyBatis 中,处理事务可以通过编程式事务管理或者声明式事务管理来实现。这里我们将分别介绍这两种方法。

  1. 编程式事务管理:

编程式事务管理是通过编写代码来管理事务的开始、提交和回滚。在 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();
            }
        }
    }
}
  1. 声明式事务管理:

声明式事务管理是通过配置文件或注解来管理事务的开始、提交和回滚。在 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 会自动为你管理事务的开始、提交和回滚。如果方法执行过程中发生异常,事务将回滚;否则,事务将提交。

0