mybatis执行器

 jdbc执行过程

 mybatis执行器层次机构(鲁班大叔讲解视频原图)

 

mybatis 大体上的执行器关系链路如图。上层的 CachingExecutor 和 BaseExecutor 各自处理一级缓存。

最基础的三个执行器负责与数据库交互。并且三者之间各有区别。

1.1 SimpleExecutor

最基础的简单执行器

org.apache.ibatis.executor.SimpleExecutor

当我们使用 mybatis 封装好的 sqlSession 会话来进行数据库交互的时候,debug 代码,就会发现底层的调用,默认就是执行到了

org.apache.ibatis.executor.SimpleExecutor#doQuery

一次查询操作在基础执行器中的流程逻辑是:

  1. 根据 mybatis 配置的 sql 全局 id 和 sql 语句的映射实体对象 mappedStatement 来获取一个配置类实体。这个配置类包含了环境配置/指定执行器类型/日志配置等等
  2. 创建一个 statement 处理器,包含了语句映射关系/分页参数/前面创建的配置类引用等等
  3. 预编译 sql 语句
  4. 执行查询操作

每次调用简单执行器的查询动作,都会执行完整的 sql 预编译过程,即这个方法:

org.apache.ibatis.executor.SimpleExecutor#prepareStatement

这是一个细微的性能损耗优化点。使用另一个基类执行器 ReuseExecutor 可以避免重复预编译完全一样的 sql,当然这个优化范围也是在 同一个 session 域内

1.2 ReuseExecutor

复用执行器

org.apache.ibatis.executor.ReuseExecutor

这里的 复用 指的是对 sql 语句预编译动作的复用。执行器内会缓存预编译通过的 sql,并在接到相同的 sql 和执行请求的时候,从本地缓存中检索出之前已经执行过的内容并执行。这样就可以省略预编译过程的性能损耗。

本地缓存,是一个 hashmap 结构:

private final Map<String, Statement> statementMap = new HashMap<>();

保存的键值对就是 sql-stmt 的映射关系集合。

mybatis 默认使用的底层执行器是 SimpleExecutor,如果想要使用 ReuseExecutor,需要在配置文件中新增配置,指定使用的执行器。

1.3 BatchExecutor

批处理执行器

org.apache.ibatis.executor.BatchExecutor

用于一次性操作更新大量数据的场景。批处理执行器在用户查询场景的时候,预编译和 simpleExecutor 是没有差别的。

注意批处理操作必须手动处理/提交事物。

1.4BaseExecutor

执行器父类

主要提供获取连接,一级缓存等公用功能。query方法提供缓存的使用。这也是经常说的mybatis基于sqlSeesion的一级缓存

1.5CachingExecutor

缓存执行器

装饰设计模式,先从缓存中获取查询结果,存在就返回,不存在,再委托给Executor delegate去数据库取,delegate可以是上面任一的SimpleExecutor、ReuseExecutor、BatchExecutor。这里是二级缓存,调用query方法时执行首先查询二级缓存,如果二级没有再查询一级缓存。这里需要注意使用二级缓存条件:1.主动开启二级缓存;2.不能有自定义的数据处理器
 

选择执行器

opensession重载方法中可传入要选择的执行器

 

 



参考:https://www.jianshu.com/p/4e00de459949,

        https://blog.csdn.net/qq1170993239/article/details/107120100

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis 执行器是用于执行查询的主要代码。在 MyBatis 中,有三种类型的执行器:简单执行器(SimpleExecutor)、可重用执行器(ReuseExecutor)和批量执行器(BatchExecutor)。可以通过配置文件来设置使用哪种执行器。其中,Executor 是 MyBatis执行器,它负责执行 SQL 语句并返回结果。 在 MyBatis 中,还有一个特殊的执行器称为 CachingExecutor,它是在 Executor 对象的基础上增加了二级缓存相关的功能。然而,由于实际使用中二级缓存的利弊不太平衡,往往被像 Redis 等产品所取代。 所以,MyBatis 执行器是用于执行查询的关键组件,根据不同的需求和配置,可以选择不同的执行器来执行 SQL 语句并返回查询结果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Mybatis中的执行器(Executor)](https://blog.csdn.net/liming0025/article/details/118632419)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [MyBatis执行器](https://blog.csdn.net/xing_jian1/article/details/123967457)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值