Mybatis源码解析

MyBatis简而言之就是一个数据库框架,一种用于简化JDBC开发的持久层框架,使用一个框架,我们不仅要知其然更要知其所以然
工作流程:
在这里插入图片描述
一些重要概念:

  • Configuration:Mybatis 所有的配置信息都维持在Configuration 对象之中
  • SqlSession:作为Mybatis 工作的主要顶层API,表示和数据库交互的会话,完成数据库增删查改功能
  • Executor:Mybatis 执行器,是Mybatis 调度的核心,负责SQL
  • StatementHandler:封装了JDBC Statement 操作,负责对JDBC statement 的操作,如设置参数,将 Statement 结果集转换为List 集合
  • ParameterHandler:负责对用户传递的参数转换为JDBC Statement 所需要的参数
  • ResultSetHandler:负责将JDBC返回的ResultSet结果集对象转换为List 类型的集合
  • MappedStatement:MappedStatement 封装了要执行的sql语句
  • MapperProxy,MapperProxyFactory:Mapper 代理,使用原生的Proxy 执行mapper 里的方法

首先来看下new SqlSessionFactoryBuilder*().build(resourceAsReader);这一步都做了些什么
在这里插入图片描述
关键步骤parser.parse
()*
在这里插入图片描述
parseConfiguration(XNode root)就是解析配置文件中各个标签
在这里插入图片描述
然后来看mapperElement解析mappers标签还做了什么

在mappers标签中三种配置方式

  1. package标签 接口所在包,通过name属性指定mapper接口所在的包名
    在这里插入图片描述
  2. mapper标签,通过resource属性引入classpath路径的相对资源
    在这里插入图片描述
  3. mapper标签,通过class属性指定mapper接口名称
    在这里插入图片描述
  4. mapper标签,通过url引入网络资源或者本地磁盘资源(较少使用)
    在这里插入图片描述
    mybatis就会根据不同配置进行解析,比如配置的是<mapper resource="com/i/mapper/FlowerMapper.xml"/>
    在这里插入图片描述
    进入到标记mapperParser.parse*();方法中
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    到此new SqlSessionFactoryBuilder
    ().build(resourceAsReader)*的工作也差不多完成了

总结一下:解析mybatis-config.xml配置文件生成configurantion对象,并解析mappers标签将对应的mapper接口封装成MapperProxyFactory添加到MapperRegistry的knowsMappers集合中。最后根据SqlSessionFactory构造函数生成SqlSessionFactory

再来看看SqlSession sqlSession = sqlSessionFactory.openSession*()*;方法都做了什么
在这里插入图片描述
在这里插入图片描述

  • SimpleExecutor:封装了jdbc的statement,使用完后直接关闭。
  • ReuseExecutor:封装了jdbc的statement,使用完后不直接关闭,放在一个缓存的map里面等待下次使用。
  • BatchExecutor:封装了jdbc的statement,有缓存功能,同时支持批量操作。

总结一下:从sqlSessionFactory中获取configuration然后创建对应的Executor对象,通过构造函数生成DefaultSqlSession

关键步骤RecordTypeMapper mapper = sqlSession.getMapper*(RecordTypeMapper.class)*; 来看下是怎么从sqlSession中获取mapper对象的
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

总结一下:sqlSession.getMapper*(RecordTypeMapper.class)*;其实是从MapperRegistry的knowsmapper中获取mapper接口的MapperProxyFactory对象然后生成并返回一个mapper的代理对象

最后再研究下Property prop = mapper.selectPropertyAutomapping*(1)*;mapper对象执行增删改查的流程
因为此时的mapper对象是一个代理对象,进入的是mapperProxy的invoke方法
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

总结一下:mapper代理对象执行,根据查询类型执行,首先看二级缓存中有没有,没有的话看一级缓存,也没有就通过PreparedStatement执行sql语句,最后处理ResultSet返回结果

单独来看下handleResultSets处理结果集
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

总结一下:就是遍历每一行进行处理,从resultset中取出每个字段的值然后通过反射创建对象

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ByLir

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值