MyBatis运行原理
文章目录
0. Mybatis四大对象
- ParameterHandler
- SqlSource
- Executor(在获取SqlSession对象时创建)
- ResultSetHandler
1.根据配置文件创建SqlSessionFactory
- 作用:解析全局配置文件中每一个信息,并保存在Configuration中,返回包含Configuration的DefaultSqlSessionFactory
-
MapperedStatement
:代表一个增删改查的详细信息
- 首先创建一个SqlSessionFactoryBuilder对象,然后该对象调用build方法并传入一个输入流,输入流读取了全局配置文件。
-
调用build方法后,首先会创建一个XMLConfigBuilder对象parser,parser是一个解析器
-
解析器parser调用parse方法对全局配置文件和mapper映射文件中的每一个标签进行解析,并把每一个标签信息保存到configuration对象中
- parser.parse()方法的返回值就是一个Configuration对象,将其传入build中
- 最后就创建了一个SqlSessionFactory对象,并且这个对象中保存了包含全局配置信息的Configuration。
2. 获取SqlSession对象(如何openSession)
- 返回一个DefaultSqlSession对象,包含了Configuration对象和Executor对象(四大对象之一)
- 这一步会创建Executor对象
- 调用sqlSessionFactory的openSession方法
-
首先从configuration中获取默认执行器的类型
defaultExecutorType 配置默认的执行器。SIMPLE 就是普通的执行器;REUSE 执行器会重用预处理语句(PreparedStatement); BATCH 执行器不仅重用语句还会执行批量更新。 SIMPLE
REUSE (可复用)
BATCH(批量处理)SIMPLE -
调用openSessionFromDataSource方法
-
获取一些信息,创建事务tx
-
关键一步,创建了一个executor对象
![在这里插入图片描述](https://www.icode9.com/i/ll/?i=7ba1771a98c04e70bab65de2ac127d54.png?,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAQmxhY2tCb3hf,size_20,color_FFFFFF,t_70,g_se,x_16)
-
-
创建DefaultSqlSession,里面包含Configuration和Executor,并返回(多态形式)
3. 获取接口的代理对象(MapperProxy)
-
DefaultSqlSession(sqlSession)对象调用getMapper方法,然后调用configuration的getMapper方法,然后调用MapperRegistry对象的getMapper方法
-
首先根据接口类型获取MapperProxyFactory对象mapperProxyFactory,然后mapperProxyFactory调用newInstance(sqlSession)方法
-
创建一个MapperProxy,它是实现了InvocationHandler接口,它就是一个InvocationHandler
-
最后返回MapperProxy代理对象,里面有sqlSession