MyBatis运行原理及部分源码流程解析

MyBatis运行原理及部分源码流程解析,第1张

MyBatis运行原理及部分源码流程解析 MyBatis运行原理

文章目录
    • MyBatis运行原理
      • 0. Mybatis四大对象
      • 1.根据配置文件创建SqlSessionFactory
      • 2. 获取SqlSession对象(如何openSession)
      • 3. 获取接口的代理对象(MapperProxy)
      • 4. 运行原理

0. Mybatis四大对象
  1. ParameterHandler
  2. SqlSource
  3. Executor(在获取SqlSession对象时创建)
  4. ResultSetHandler

1.根据配置文件创建SqlSessionFactory
  • 作用:解析全局配置文件中每一个信息,并保存在Configuration中,返回包含Configuration的DefaultSqlSessionFactory
  • MapperedStatement:代表一个增删改查的详细信息

  1. 首先创建一个SqlSessionFactoryBuilder对象,然后该对象调用build方法并传入一个输入流,输入流读取了全局配置文件。

  1. 调用build方法后,首先会创建一个XMLConfigBuilder对象parser,parser是一个解析器

  2. 解析器parser调用parse方法对全局配置文件和mapper映射文件中的每一个标签进行解析,并把每一个标签信息保存到configuration对象中

  1. parser.parse()方法的返回值就是一个Configuration对象,将其传入build中

  1. 最后就创建了一个SqlSessionFactory对象,并且这个对象中保存了包含全局配置信息的Configuration。
2. 获取SqlSession对象(如何openSession)
  • 返回一个DefaultSqlSession对象,包含了Configuration对象和Executor对象(四大对象之一)
  • 这一步会创建Executor对象
  1. 调用sqlSessionFactory的openSession方法

  1. 首先从configuration中获取默认执行器的类型

    defaultExecutorType配置默认的执行器。SIMPLE 就是普通的执行器;REUSE 执行器会重用预处理语句(PreparedStatement); BATCH 执行器不仅重用语句还会执行批量更新。SIMPLE
    REUSE (可复用)
    BATCH(批量处理)SIMPLE

  2. 调用openSessionFromDataSource方法

    1. 获取一些信息,创建事务tx

    2. 关键一步,创建了一个executor对象

    ![在这里插入图片描述](https://img-blog.csdnimg.cn/7ba1771a98c04e70bab65de2ac127d54.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAQmxhY2tCb3hf,size_20,color_FFFFFF,t_70,g_se,x_16)
    
  3. 创建DefaultSqlSession,里面包含Configuration和Executor,并返回(多态形式)

3. 获取接口的代理对象(MapperProxy)

  1. DefaultSqlSession(sqlSession)对象调用getMapper方法,然后调用configuration的getMapper方法,然后调用MapperRegistry对象的getMapper方法

  1. 首先根据接口类型获取MapperProxyFactory对象mapperProxyFactory,然后mapperProxyFactory调用newInstance(sqlSession)方法

  2. 创建一个MapperProxy,它是实现了InvocationHandler接口,它就是一个InvocationHandler

  3. 最后返回MapperProxy代理对象,里面有sqlSession

4. 运行原理

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5562947.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-14
下一篇2022-12-14

发表评论

登录后才能评论

评论列表(0条)

    保存