一图读懂mybatis 查询接口的源码流程

请添加图片描述

图比较大:如果看着比较糊的话,可以下载高清图:https://download.csdn.net/download/langwuzhe/87376216

第一步:创建 StatementHandler、ParameterHandler、ResultSetHandler-----------(三剑客的新生)
  1. 创建 StatementHandler 对象
    • 具体创建的实现类是 PreparedStatementHandler ,而且被 RoutingStatementHandler包裹,便于识别具体的 StatementHandler对象。
  2. 在创建 StatementHandler 对象时,会同时super()父类 BaseStatementHandler 的构造器。BaseStatementHandler构造器会把 ParameterHandlerResultSetHandler 都创建出来
    • ParameterHandlerResultSetHandler 这两个Handler 是在StatementHandler的实现类中创建出来的,所以当要调用 这两个Handler 的方法时需要去 StatementHandler 的实现中寻找这两个Hander 的引用。所以就会看见上图中 设置参数 和 整理数据库返回数据时依然会看见需要经过 StatementHandler的实现类PrepareStatementHandler
第二步:执行 connection.prepareStatement,返回 statement 对象---------(StatementHandler)
  1. 经过一系列流转,具体是在 StatementHandler 的实现类中执行的 connection.prepareStatement
  2. connection.prepareStatement(sql)时,由于connection 对象被种了动态代理的蛊。所以执行 connection.prepareStatement(sql)时,会先进入 connection的代理对象 ConnectionLogger中执行invoke方法 打印sql日志

第三步:往sql中设置参数。具体值 替换 ? 问号 -------------- (ParameterHandler)

  1. 把第二步的statement对象传出来用来往sql设置参数
  2. 使用具体参数 替换 ? 问号时,是在ParameterHandler的实现类 DefaultParameterHandler进行的
第四步:执行 statement.execute() ------------------------(StatementHandler)
  1. 执行 execute()方法是在 StatementHandler 的实现类 PreparedStatementHandler 中执行的。
  2. 由于 PreparedStatement 对象被种了动态代理的蛊,所以执行 他的execute()方法,会先进入到 PreparedStatement的代理的对象 PreparedStatementLogger打印入参的日志。
第五步:数据库返回数据结果映射。---------------------------(ResultSetHandler)
  1. 结果映射都是在 ResultSetHandler 的实现类 DefaultResultSetHandler 中进行的。

  2. 从 statement中取出 ResultSet 对象会把他放到 ResultSetWrapper 中,ResultSetWrapper是对ResultSet 的补充增强

  3. 在映射的过程中,还会创建 ResultHandler对象,他的实现类是 DefaultResultHandler。这个只是方法返回时携带数据用的,无需过多关注,但是要区分ResultSetHandlerResultHandler 长的很像,容易看花眼。

注:

​ 第一、二、三 步 都是在 Executor 中发生的。第四、五步 是在 StatementHandler 中发生的。
**

在这里插入图片描述

另外在我的组件库中,对mybatis源码进行了详尽的注释,且可以对项目进行install,然后在ron-man-mybatis1项目中 src/main/java/iron/man/lyf/ironmanmybatis1/run_test/MybatisQuickStart.java 进行运行 对mybatis源码进行debug查看运行过程,欢迎大家下载指正。如果您觉得帮助到您麻烦给个赞。 我的组件库

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值