MyBatis BaseDao層如何處理事務(wù)

小樊
82
2024-09-10 03:04:24

在 MyBatis 中,處理事務(wù)可以通過(guò)編程式事務(wù)管理或者聲明式事務(wù)管理來(lái)實(shí)現(xiàn)。這里我們將分別介紹這兩種方法。

  1. 編程式事務(wù)管理:

編程式事務(wù)管理是通過(guò)編寫(xiě)代碼來(lái)管理事務(wù)的開(kāi)始、提交和回滾。在 MyBatis 中,你可以使用 SqlSession 對(duì)象來(lái)實(shí)現(xiàn)編程式事務(wù)管理。以下是一個(gè)簡(jiǎn)單的示例:

public class BaseDao {
    private SqlSessionFactory sqlSessionFactory;

    public BaseDao(SqlSessionFactory sqlSessionFactory) {
        this.sqlSessionFactory = sqlSessionFactory;
    }

    public void saveData(Object data) {
        SqlSession sqlSession = null;
        try {
            // 開(kāi)啟事務(wù)
            sqlSession = sqlSessionFactory.openSession();
            sqlSession.insert("YourMapperNamespace.saveData", data);

            // 提交事務(wù)
            sqlSession.commit();
        } catch (Exception e) {
            // 回滾事務(wù)
            if (sqlSession != null) {
                sqlSession.rollback();
            }
            throw new RuntimeException("Error saving data", e);
        } finally {
            // 關(guān)閉 SqlSession
            if (sqlSession != null) {
                sqlSession.close();
            }
        }
    }
}
  1. 聲明式事務(wù)管理:

聲明式事務(wù)管理是通過(guò)配置文件或注解來(lái)管理事務(wù)的開(kāi)始、提交和回滾。在 Spring 框架中,你可以使用 @Transactional 注解來(lái)實(shí)現(xiàn)聲明式事務(wù)管理。首先,需要在 Spring 配置文件中配置事務(wù)管理器:

<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);
    }
}

這樣,當(dāng) saveData 方法執(zhí)行時(shí),Spring 會(huì)自動(dòng)為你管理事務(wù)的開(kāi)始、提交和回滾。如果方法執(zhí)行過(guò)程中發(fā)生異常,事務(wù)將回滾;否則,事務(wù)將提交。

0