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 を確認します
ここでは主に次の 1 つを返します。独自のクラスメソッド 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的配置信息和DefaultSqlSession2: MyBatis ツールクラスの sqlSession.close() の最下層がなぜトランザクションをロールバックしますか?
まず close() と入力して、その実装クラス DefaultsqlSession を見つけます
DefaultsqlSession の close メソッド
れーるー
るーるーまた、なぜcloseはトランザクションを送信する前にロールバックし、送信された後にトランザクションを閉じるのかについて
主にExecutorの実装クラスBaseExecutorに依存します
session.close(); 底层为什么可以回滚事务?????<br>DefaultsqlSession里的close方法<br>
session.commit( ); なぜトランザクションを送信できるのですか? その実装 close() の実装は基本的に同じで、主に true の場合はトランザクションが送信され、false の場合はセッションが閉じられます。
<br>
以上がMyBatis openSession()、close()、および commit() の使用法の説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。