ホームページ  >  記事  >  Java  >  MyBatis openSession()、close()、および commit() の使用法の説明

MyBatis openSession()、close()、および commit() の使用法の説明

巴扎黑
巴扎黑オリジナル
2017-07-24 15:56:174760ブラウズ

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的配置信息和DefaultSqlSession

2: 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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。