Mybatis三大执行器介绍

本文用的是3.5.10版本
源码地址:https://github.com/mybatis/mybatis-3/releases
文档地址:https://mybatis.org/mybatis-3/zh/sqlmap-xml.html

Mybatis相关全览

一. Mybatis源码详解
二. Mybatis二级缓存详解
三. Mybatis三大执行器介绍
四. Mybatis拦截器源码详解

一、执行器介绍

在这里插入图片描述

Mybatis中执行器关系如上图所示,真正生效并在最后执行中有着不同效果的只有三个执行器:

  • SimpleExecutor: 默认的执行器, 对每条sql进行预编译->设置参数->执行等操作
  • BatchExecutor: 批量执行器, 对相同sql进行一次预编译, 然后设置参数, 最后统一执行操作
  • ReuseExecutor: 重用执行器会重用预处理语句(prepared statements)

BaseExecutor:只是一个抽象类抽出了三个执行器公共的一些方法,以及提供了需要重写的方法

CachingExecutor:专门用来作为二级缓存使用,不负责具体执行方法

执行器的选择入口

执行器的选择就在获取SqlSession的时候

在这里插入图片描述

内部会调用DefaultSqlSessionFactory.openSessionFromDataSource

可以会根据ExecutorType来选择获取某种类型执行器,我们平时不会传参,所以默认就是SimpleExecutor

在这里插入图片描述

ExecutorType有三种类型,正好与三种执行器对应

在这里插入图片描述

设置执行器两种方式

全局配置(不建议)

在XML配置文件中全局设置

<settings>
    <setting name="defaultExecutorType" value="BATCH" />
</settings>

局部设置(建议)

就是在获取SqlSession的时候传参,指定该SqlSession采用某种执行器执行
在这里插入图片描述

二、三个执行器区别

上述的介绍可能还不是很直观的发现三个执行器的区别,下面开启日志,通过一个例子直观的感受一下区别吧

SimpleExecutor

我们指定采用简单执行器,遍历插入10条数据,看看日志结果:

发现每次插入都伴随了预编译→参数处理→执行 三个步骤

在这里插入图片描述

ReuseExecutor

我们指定重用执行器,同样遍历插入10条数据,看看日志结果:

发现只会有一次预编译,然后就是多次的传参处理和执行

在这里插入图片描述

BatchExecutor

我们指定批量执行器,同样遍历插入10条数据,看看日志结果:

发现只会有一次预编译,多次传参处理,一次执行

在这里插入图片描述

总结

从上述结果可以清晰的看到三种执行器的区别了:就体现在一条语句多次执行在预编译、传参处理和执行的次数上

  • SimpleExecutor: 多次预编译、多次传参处理、多次执行
  • BatchExecutor: 一次预编译、多次传参处、一次执行
  • ReuseExecutor: 一次预编译、多次传参处理、多次执行

那省了这些步骤到底有多大提升呢?下面我们测试看看

三、效率测试

我们以插入100条数据简单的测试下三种执行器各自需要多长时间

SimpleExecutor:1.7 秒

在这里插入图片描述

ReuseExecutor:1.6 秒
在这里插入图片描述

BatchExecutor:1 秒

在这里插入图片描述

上述测试还会因物理环境、SQL复杂程度变化而变化,结果不一定准,但是主要是为了证明在这种场景下三个执行器的执行效率,从结果上来说ReuseExecutor带来的提升微乎其微,而BatchExecutor在批量删除、更新、插入这种场景下效率还是不错的,可以视场景使用

四、平时开发使用

平时开发都是结合Spring来使用的,直接获取IOC容器中的mapper就来用了,连SqlSession的影子都没看到,可能很多人连SqlSession是个什么东西都不知道,怎么根据SqlSession去设置某执行器?

万变不离其宗,平时在Spring环境中确实不能直接获取到SqlSession,但是我们可以获取SqlSessionFactory啊,通过工厂在获取SqlSession不一样嘛?

源代码如下:

// 从容器中获取SqlSession工厂
@Resource
private SqlSessionFactory sqlSessionFactory;

public void test2(){
    SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
    XxxxMapper mapper = sqlSession.getMapper(XxxxMapper .class);
    //......
    // 批量操作记得手动提交
    sqlSession.commit();
    sqlSession.close();
}
  • 5
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值