Mybatis运行原理
一.运行过程中涉及到的类
1. Resources Mybatis中IO流的工具类
1.1 加载配置文件
2. SqlSessionFactoryBuilder()构建器
2.1 作用:创建SqlSessionFactory接口中的实现类
3. XMLConfigBuilder Mybatis全局配置文件内容构建器类
3.1 作用:负责读取流内容并转换为JAVA代码
4. Configuration 封装了全局配置文件所有配置信息
4.1 全局配置文件的内容存放在Configuration中
5. DefaultSqlSessionFactory是SqlSessionFactory接口的实现类
6. Transaction事务类
6.1 每个SqlSession都会带有一个Transaction对象
7. TransactionFactory事务工厂
7.1 负责生产Transaction
8. Executor Mybatis执行器
8.1 作用:负责执行SQL命令
8.2 相当于JDBC中statement对象(或PreparedStatement或CallableStatement)
8.3 默认执行SimpleExcutor
8.4 批量操作 BatchExcutor
8.5 通过OpenSession(参数控制)
9. DefaultSqlSession是SqlSession接口的实现类
10. ExceptionFactory Mybatis中异常工厂
二. 流程图
三. 文字解释
在Mybatis运行开始时需要先通过Resources加载全局配置文件,下面需要实例化SqlSessionFactoryBuilder构建器,帮助SqlSessionFactory接口实现类DefaultSqlSessionFactory。
在实例化DefaultSqlSessionFactory之前需要先创建XMLConfigBuilder解析全局配置文件流,并把解析结果存放在Configuration中,之后把Configuration传递给DefaultSqlSessionFactory,到此SqlSessionFactory工厂创建成功。
由SqlSessionFactory工厂创建SqlSession,每次创建SqlSession时,都需要由TransactionFactory创建Transaction对象,同时还需要创建SqlSession的执行器Excutor,最后实例化DefaultSqlSession,传递给SqlSession接口
根据项目需求使用SqlSession接口中的API完成具体的事务操作,如果事务执行失败,需要进行rollback回滚事务;如果事务执行成功,提交给数据库,关闭SqlSession。