Mybatis 트랜잭션 관리 SqlSession

SqlSession 객체

  • getMapper(DAO.class): 매퍼 가져오기(DAO 인터페이스 인스턴스)
  • 거래 관리

수동으로 거래 제출

  1. factory.openSession()또는factory.openSession(false)
  2. 일련의 작업을 완료하세요.
  3. sqlSession.commit()
  4. 작업 중 오류가 발생하면 pass trycatch, 예외 발생, sqlSession.rollback()롤백 사용

자동으로 트랜잭션 커밋

  1. factory.openSession(true)
  2. 작업을 완료합니다. 여기에서 수행되는 데이터 작업은 데이터의 일관성을 보장해야 합니다. 중간 작업 중 하나에 오류가 있으면 이전 작업이 롤백되지 않아 데이터의 일관성이 파괴됩니다.
  3. 를 통과하고 trycatch, 예외를 발생시키고, sqlSession.rollback()롤백을 사용하더라도 오류가 발생한 작업만 롤백하며, 이전 작업은 자동으로 제출되었습니다.

Mybatis의 SqlSession 캡슐화

public class MyBatisUtil {
    
    
    private static SqlSessionFactory factory;
    private static ThreadLocal<SqlSession> threadLocal = new ThreadLocal<SqlSession>();
    static {
    
    
        try {
    
    
            InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
            factory = new SqlSessionFactoryBuilder().build(is);
        } catch (IOException e) {
    
    
            e.printStackTrace();
        }
    }
    private static SqlSession getSqlSession(boolean isAutoCommit){
    
    
        SqlSession sqlSession = threadLocal.get();
        if( sqlSession == null ){
    
    
            // 通过SqlSessionFactory调用openSession方法,获取sqlSession对象时,可以通过参数设置事务是否自动提交
            // factory.openSession(true) 自动提交
            // factory.openSession() 或 factory.openSession(false) 手动提交
            sqlSession = factory.openSession(isAutoCommit);
            threadLocal.set(sqlSession);
        }
        return sqlSession;
    }
    public static SqlSessionFactory getFactory(){
    
    
        return factory;
    }
    public static SqlSession getSqlSession(){
    
    
        // 返回sqlSession对象,因此希望进行事务管理,所以使用手动提交
        return getSqlSession(false);
    }
    public static <T extends Object> T getMapper(Class<T> c){
    
    
        // 不对外输出获取sqlSession对象,因此不想进行事务管理,所以使用自动提交
        return getSqlSession(true).getMapper(c);
    }
}

테스트 수업에 사용

@org.junit.Test
public void insertStudent() {
    
    
    // 手动事务管理
    SqlSession sqlSession = MyBatisUtil.getSqlSession();
    // 获取sqlSession对象,就默认开启事务
    try{
    
    
        // 通过会话,获取DAO对象
        StudentDao studentDao = sqlSession.getMapper(StudentDao.class);
        // 调用被测试方法
        Student student = new Student(0, "10004", "张三", "男", 20);
        int i = studentDao.insertStudent(student);
        // 手动提交事务:如果一个中间的某一个操作出错,就不会执行commit,于是就会执行rollback,取消之前的操作
        // 自动提交事务:每一个操作都会提交,当中间的某一个操作出错,不会回滚之前的操作
        // 如果有多个操作,需要手动提交事务,否则会破坏数据的一致性
        // 操作完成并成功后,需要手动提交事务,同步到数据库
        sqlSession.commit();
    }catch(Exception e){
    
    
        // 操作出现异常,调用rollback进行回滚
        sqlSession.rollback();
    }
}
@Test
public void queryStudentList() {
    
    
	try{
    
    
	    StudentDao studentDao = MyBatisUtil.getMapper(StudentDao.class);
	    List<Student> students = studentDao.queryStudentList();
    }catch(Exception e){
    
    
        // 操作出现异常,调用rollback进行回滚
        sqlSession.rollback();
    }
}

디렉토리 구조

여기에 이미지 설명을 삽입하세요.

추천

출처blog.csdn.net/weixin_55556204/article/details/125082872