mybatis -- StatementHandler

statement结构图

在这里插入图片描述
statement的结构图与Executor很相似, 常用的就是预处理器, 以下的讲解都是围绕预处理器

执行流程

在这里插入图片描述

  • 声明statement, 创建statement
  • 为preparedStatement设置参数, 解析并填充参数
  • 调用execute()方法执行sql
  • 结果集处理

源码分析

直接进入到执行器的doQuery()方法里面
在这里插入图片描述
58行创建了一个StatementHandler对象 , 默认是RoutingStatementHandler类型, 里面包含了一个PrearedStatementHandler类型的对象, 这块用的也是装饰器模式
在这里插入图片描述
进入58行
在这里插入图片描述
此处相当于一个Statement缓存获取, 84行根据83行sql去获取Statement, 如果不为null, 则使用上一次的Statement对象, 这就是为什么相同的sql进行多次查询只编译一次
因为是第一次查询, 所以会走else逻辑, 并在90行将sql作为key, Statement作为value存入到map中, 用于下次if获取

接下来进入92行, 最终会走到setParameters()方法

不同类型的参数解析

接下来根据这4中不同情况, 分别查看mybatis是怎么解析参数的
在这里插入图片描述

只有一个参数, 没有标记@Param注解

在这里插入图片描述
通过86行进行参数转换, 进入该方法
在这里插入图片描述
由于该方法没有@Param注解, 且 参数个数唯一 所以会走127-128行逻辑,
value 值为1, names.get(0)值为"id"
进入128行
在这里插入图片描述
由于object既不是集合也不是数组 , 所以直接走170行返回, 参数解析完成

多个参数, 都没有标记@Param注解

在这里插入图片描述

将会走130行逻辑, 在133行和138行将属性名与属性值封装成一个map

多个参数, 其中有一个标注了@Param注解

在这里插入图片描述
根据@Param注解中配置的值作为map的key

多个参数, 其中有一个参数是对象类型

在这里插入图片描述

进行一个错误配置

在这里插入图片描述
测试代码
在这里插入图片描述

返回的参数映射
在这里插入图片描述
在这里插入图片描述
这个方法将会抛出异常, 这个方法是用来配置一级缓存的key的 进入此方法
在这里插入图片描述
在此处需要获取user111.id, 但是我们只有user.id, 所以获取失败, 会抛出异常

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值