mybatis小结四

Posted 名人堂之路

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mybatis小结四相关的知识,希望对你有一定的参考价值。

对mybatis初始化SessionFactory过程做一个小结

1.调用 SqlSessionFactoryBuilder 对象的 build(inputStream) 方法;
2.SqlSessionFactoryBuilder 会根据输入流 inputStream 等信息创建XMLConfigBuilder 对象 ;
3.SqlSessionFactoryBuilder 调用 XMLConfigBuilder 对象的 parse() 方法;
4.XMLConfigBuilder 对象返回 Configuration 对象;
5.SqlSessionFactoryBuilder 根据 Configuration 对象创建一个DefaultSessionFactory 对象;
6.SqlSessionFactoryBuilder 返回 DefaultSessionFactory 对象给 Client ,供 Client使用。

结合上面的过程可以很清晰的理解下面的源码的内容。

sessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
//build对应的源码
public SqlSessionFactory build(InputStream inputStream, String environment, Properties properties) {
    SqlSessionFactory var5;
    try {
        XMLConfigBuilder parser = new XMLConfigBuilder(inputStream, environment, properties);
//这部分主要进行xml文件的解析
        var5 = this.build(parser.parse());
    } catch (Exception var14) {
        throw ExceptionFactory.wrapException("Error building SqlSession.", var14);
    } finally {
        ErrorContext.instance().reset();

        try {
            inputStream.close();
        } catch (IOException var13) {
            ;
        }
    }
    return var5;
}
//this.build对应的源码
public SqlSessionFactory build(Configuration config) {
    return new DefaultSqlSessionFactory(config);
}
//获取session
public static SqlSession getSession(){
    //默认自动提交
    return sessionFactory.openSession();
}
//openSession()对应的源码
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;
}


以上是关于mybatis小结四的主要内容,如果未能解决你的问题,请参考以下文章

验证码逆向专栏某验四代文字点选验证码逆向分析

验证码逆向专栏某验四代消消乐验证码逆向分析

MyBatis-05-笔记

Mybatis关于复杂的SQL查询的处理&Mybatis的缓存机制

Mybatis关于复杂的SQL查询的处理&Mybatis的缓存机制

Mybatis学习小结