MyBatis03—SQL的执行,以SimpleExecutor为例

0 参考

https://blog.csdn.net/javageektech/article/details/96539536
https://www.jianshu.com/p/86289c7c8237

1 SQL的执行

  • 创建 StatementHandler

  • 创建 Statement在这里插入图片描述

  • 在 StatementHandler中调用 Statement 的SQL执行方法 execute
    在这里插入图片描述

  • 调用结果处理器 resultHandler 处理返回结果


2 StatementHandler 与 Statement

MappedStatement—>Configuration—>StatementHandler
StatementHandler handler = configuration.newStatementHandler(xxx);

2.1 Executor: 创建处理器 StatementHandler

l来源 https://blog.csdn.net/javageektech/article/details/96539536在这里插入图片描述

2.1.1 三种StatementHandler

  • SimpleStatementHandler
  • ParparedStatementHandler
  • CallableStatementHandler

2.1.2 RoutingStatementHandler

MyBatis 真正使用的实现类,根据statementType选择要创建的Handler
在这里插入图片描述 在这里插入图片描述

2.2 Executor: handler作为参数,调用prepareStatement 方法

在这里插入图片描述

2.3 Handler: 调用prepare方法

在这里插入图片描述

2.4 Handler: instantiateStatement

instantiateStatement ,是一个抽象方法由子类去实现,不同的 Handler 通过Connection 创建不同类型的 Statement 对象
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值