mybatis session创建过程(2)

简介: session创建过程 在mybatis的常规用法当中,通过sqlSessionFactory.openSession()来创建SqlSession对象,这里的sqlSessionFactory就是在解析配置后生成的SqlSession的工厂。

session创建过程

 在mybatis的常规用法当中,通过sqlSessionFactory.openSession()来创建SqlSession对象,这里的sqlSessionFactory就是在解析配置后生成的SqlSession的工厂。

public class MyBatisTest {
    public static void main(String[] args) throws Exception {
        String resource = "configuration.xml";
        Reader reader = Resources.getResourceAsReader(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder()
                .build(reader);
        SqlSession sqlSession = sqlSessionFactory.openSession();
        User user = sqlSession.selectOne("userTest.selectUser", 1);
        System.out.println(user.getUsername());
        sqlSession.close();
    }
}



在openSession过程中我们按照下面顺序创建SqlSession对象

  • 生成mybatis的Environment对象
  • 生成TransactionFactory对象
  • 生成Transaction对象
  • 生成Executor对象
  • 生成DefaultSqlSession对象
  public SqlSession openSession() {
    return openSessionFromDataSource(configuration.getDefaultExecutorType(), null, false);
  }


  private SqlSession openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit) {
    Transaction tx = null;
    try {
      final Environment environment = configuration.getEnvironment();
      final TransactionFactory transactionFactory = getTransactionFactoryFromEnvironment(environment);
      tx = transactionFactory.newTransaction(environment.getDataSource(), level, autoCommit);
      final Executor executor = configuration.newExecutor(tx, execType);
      return new DefaultSqlSession(configuration, executor, autoCommit);
    } catch (Exception e) {
      closeTransaction(tx); // may have fetched a connection so lets call close()
      throw ExceptionFactory.wrapException("Error opening session.  Cause: " + e, e);
    } finally {
      ErrorContext.instance().reset();
    }
  }


  private TransactionFactory getTransactionFactoryFromEnvironment(Environment environment) {
    if (environment == null || environment.getTransactionFactory() == null) {
      return new ManagedTransactionFactory();
    }
    return environment.getTransactionFactory();
  }


session组件依赖图

 通过下面这个图基本上把mybatis里面几个组件的创建顺序描述清楚了。


img_32fcd3e1f67d306c0a623ecf347b6d97.png
mybatis组件关系图


session组件类关系图

 通过下面这个图,基本上就把mybatis里面核心的几个类的继承包含关系描述清楚了。


img_4fa490116e1707aaa1756895473bcfad.png
mybatis组件类关系图
目录
相关文章
|
9月前
|
XML Java 数据库连接
一起剖析Mybatis初始化过程中的六个牛逼工具
一起剖析Mybatis初始化过程中的六个牛逼工具
45 0
|
9月前
|
前端开发 Java 数据库连接
Mybatis-Plus 逻辑删除
Mybatis-Plus 逻辑删除
|
9月前
|
SQL 缓存 Java
Mybatis二级缓存创建过程与使用详解
Mybatis二级缓存创建过程与使用详解
102 0
|
SQL XML Java
MyBatis原理分析之查询单个对象-2
MyBatis原理分析之查询单个对象-2
85 0
|
缓存 Java 数据库连接
MyBatis原理分析之查询单个对象-1
MyBatis原理分析之查询单个对象-1
103 0
Mybatis-plus实现逻辑删除
Mybatis-plus实现逻辑删除
214 0
|
SQL XML 缓存
mybatis与hibernate运行流程比较
mybatis与hibernate运行流程比较
119 0
mybatis与hibernate运行流程比较
|
SQL 数据库
mybatis-plus逻辑删除
mybatis-plus逻辑删除
|
XML SQL 缓存
MyBatis Mapper 接口方法执行原理分析
前言 通过前面入门 MyBatis 的文章《MyBatis 初探,使用 MyBatis 简化数据库操作(超详细)》,我们已经对 MyBatis 有了一定了解。
479 0
|
XML SQL Java
MyBatis——创建mapper、mybatis主配置文件模板、使用工具类或传统dao方式实现数据库的一些操作、MyBatis代理
MyBatis——创建mapper、mybatis主配置文件模板、使用工具类或传统dao方式实现数据库的一些操作、MyBatis代理
MyBatis——创建mapper、mybatis主配置文件模板、使用工具类或传统dao方式实现数据库的一些操作、MyBatis代理

热门文章

最新文章