重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

一图读懂mybatis查询接口的源码流程-创新互联

请添加图片描述

站在用户的角度思考问题,与客户深入沟通,找到城步网站设计与城步网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:成都做网站、成都网站制作、企业官网、英文网站、手机端网站、网站推广、国际域名空间、网页空间、企业邮箱。业务覆盖城步地区。

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

第一步:创建 StatementHandler、ParameterHandler、ResultSetHandler-----------(三剑客的新生)
  1. 创建StatementHandler对象
    • 具体创建的实现类是PreparedStatementHandler,而且被RoutingStatementHandler包裹,便于识别具体的StatementHandler对象。
  2. 在创建 StatementHandler 对象时,会同时super()父类BaseStatementHandler的构造器。BaseStatementHandler构造器会把ParameterHandlerResultSetHandler都创建出来
    • ParameterHandler 、ResultSetHandler 这两个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。这个只是方法返回时携带数据用的,无需过多关注,但是要区分ResultSetHandler 和 ResultHandler 长的很像,容易看花眼。

注:

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

在这里插入图片描述

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

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


新闻名称:一图读懂mybatis查询接口的源码流程-创新互联
网站路径:http://cqcxhl.com/article/dpjgjg.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP