>Java >java지도 시간 >MyBatis openSession(), close(), commit() 사용법 설명

MyBatis openSession(), close(), commit() 사용법 설명

巴扎黑
巴扎黑원래의
2017-07-24 15:56:174795검색

1: MyBatis 도구 클래스에서 openSession은 정확히 무엇을 합니까?

Mybatis 도구 클래스

 1     private static final String RESOURCE = "mybatis-config.xml"; 2     private static SqlSessionFactory sqlSessionFactory = null; 3     private static ThreadLocal<SqlSession> threadLocal = new ThreadLocal<SqlSession>(); 4  5  6  7  8     //关闭sqlsession 9     public static void closeSession(){10         SqlSession session = (SqlSession) threadLocal.get(); // 211         threadLocal.set(null);12         if (session !=null){13             session.close();14         }15     }16 17     public static SqlSession getSessionTwo() {18         //读取配置文件19         try {20             InputStream stream = Resources.getResourceAsStream(RESOURCE);21             sqlSessionFactory = new SqlSessionFactoryBuilder().build(stream);22 23             return sqlSessionFactory.openSession();   //返回openSession24         } catch (IOException e) {25             e.printStackTrace();26         }27 28         return null;29     }

먼저 openSession을 클릭하여 sqlsessionFactory

 1 package org.apache.ibatis.session; 2  3 import java.sql.Connection; 4  5 public interface SqlSessionFactory { 6     SqlSession openSession(); 7  8     SqlSession openSession(boolean var1); 9 10     SqlSession openSession(Connection var1);

이 메서드의 구현 클래스를 살펴보세요. DefaultSqlSessionFactory

여기에서는 주로 다음 중 하나를 반환합니다. 자체 클래스 메소드 openSessionFroDataSource()(데이터 소스) 및 autoCommit을 false로 할당

한 다음 이 메소드를 입력

 private SqlSession openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit) {
        Transaction tx = null;

        DefaultSqlSession var8;try {
            Environment environment = this.configuration.getEnvironment();
            TransactionFactory transactionFactory = this.getTransactionFactoryFromEnvironment(environment);
            tx = transactionFactory.newTransaction(environment.getDataSource(), level, autoCommit);
            Executor executor = this.configuration.newExecutor(tx, execType);
            var8 = new DefaultSqlSession(this.configuration, executor, autoCommit);
        } catch (Exception var12) {this.closeTransaction(tx);throw ExceptionFactory.wrapException("Error opening session.  Cause: " + var12, var12);
        } finally {
            ErrorContext.instance().reset();
        }return var8;
    }

<br>
可以看到他这个方法主要是初始化一些configure.xml的配置信息和DefaultSqlSession
configure.xml的配置信息和DefaultSqlSession

2: MyBatis 도구 클래스에서 sqlSession.close()의 하위 레이어가 왜 작동합니까? 거래를 롤백하시겠습니까?

먼저 close()를 입력하여 구현 클래스 DefaultsqlSession

DefaultsqlSession의 close 메소드

session.close(); 底层为什么可以回滚事务?????<br>DefaultsqlSession里的close方法<br>
rr ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ
또한 close가 제출되기 전에 트랜잭션을 롤백하고 제출된 후에 트랜잭션을 닫는 이유는 주로 Executor의 BaseExecutor 구현 클래스에 달려 있습니다
 public void close() {try {this.executor.close(this.isCommitOrRollbackRequired(false));this.dirty = false;
        } finally {
            ErrorContext.instance().reset();
        }

    }
session.commit( ); 트랜잭션을 제출할 수 있는 이유는 무엇입니까? 구현 close()의 구현은 기본적으로 동일합니다. 중요한 것은 매개변수가 true인지 false인지입니다.

세션을 종료합니다.

위 내용은 MyBatis openSession(), close(), commit() 사용법 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.