MyBatis运行原理
1. 涉及到的接口和类:
> Resources, 类, 用于加载核心配置文件, 返回InputStream
> SqlSessionFactoryBuilder, 类, 工厂对象的构建类, 用于基于输入流
创建工厂对象
> SqlSessionFactory, 接口, 用于创建SqlSession对象的工厂
> SqlSession, 接口, MyBatis中的核心对象
> XmlConfigBuilder, 类, 解析器, 解析MyBatis核心配置文件的解析器
> Configuration, 类, 解析器解析完后生成的结果, 存放MyBatis所有的
配置信息
> DefaultSqlSessionFactory, 类, 是SqlSessionFactory接口的实现类
> DefaultSqlSession, 类, 是SqlSession接口的实现类
> Executor, 接口, 是MyBatis中执行SQL语句的执行器
> SimpleExecutor, 类, 是Execu接口的实现类, 默认使用的执行器
> TransactionFactory, 接口, 用于创建Transaction对象的工厂
> Transaction, 接口, 表示事务对象
> MappedStatement, 类, 表示映射文件中配置的要执行的sql语句
2. MyBatis开始运行后, 先要通过Resources加载核心配置文件, 得到一个输入流,
将输入流作为参数传入SqlSessionFactoryBuilder的buid方法中, 用于创建SqlSessionFactory对象;
在创建SqlSessionFactory对象的时候, 会先创建一个XmlConfigBuilder对象, 这个对象可以被称之为解析器, 用来解析核心配置文件, 解析结果被封装为一个Configuration对象. 基于Configuration对象可以创建一个DefaultSqlSessionFactory对象. 这样就创建了工厂对象.
工厂对象创建成功后, 程序员可以通过调用openSession方法创建SqlSession对象,
SqlSession对象是MyBatis中的核心对象, 所有的数据库操作都是基于这个对象完成的.
下面我详细说一下SqlSession对象的创建过程.
首先, 需要先借助TransactionFactory工厂去创建Transaction事务对象,
然后, 基于事务对象创建一个Executor执行器, 默认MyBatis使用的是SimpleExecutor.
接下来, 基于执行器, 创建DefaultSqlSession对象, 到此为止, SqlSession对象创建成功. 程序员可以基于SqlSession调用相应的方法进行数据库的增删改查,
查询底层使用执行器的query方法实现,
增删改底层调用执行器的update方法实现.
操作结束时, 如果没有异常, 则可以调用SqlSession的commit方法提交事务; 如果发生异常, 可以调用SqlSession的rollback方法进行事务的回滚.
所有流程结束后, 调用SqlSession的close方法进行资源的关闭. 以上就是MyBatis的执行流程.