Mybatis实现原理,步骤如下:
1.构建SqlSessionFactory过程
SqlSessionFactory接口是Mybatis操作数据库的入口,相当于JDBC 的Connection 类型,它提供创建 Mybatis 核心接口SqlSession
创建过程:
第一步:XMLConfigBuilder 解析xml 配置文件 ,生产 Configuration对象,所有的配置信息
都会解析到Configuration里面
第二步:Configuration对象去创建 SqlSessionFactory实现类 DefaultSqlSessionfactory,
InputStreaminputStream = Resources.getResourceAsStream(resource)
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder.build(inputStream);
2. 生产SqlSession sqlSessionFactory.openSession();
SqlSession 是Mybatis实际的操作数据库对象,事务,执行器都是在创建SqlSession是生产。
创建步骤:
第一步:生成事务工厂对象 TransactionFactory,在事务工厂中创建事务对象。
第二步:生成执行器Executor,执行器有三种类型SIMPLE,REUSE,BATCH 。
SIMPLE:常规执行器,默认就是此类型执行器,每次执行都会创建一个statement,用完后关闭
REUSE:可重用执行器,将statement存入map中,操作map中的statement而不会重复创建statement
BATCH:批处理执行器,doUpdate预处理存储过程或批处理操作,doQuery提交并执行过程
第三步:就是生成SqlSession的实现类DefaultSqlSession
3. SqlSession 通过映射器,执行操作
映射器是通过动态代理来实现的,通过动态代理,生成Mapper的实现类,和实际的执行方法,执行sql。
下篇代理模式,顺便谈SqSession 映射器原理
流程图如下: