码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Mybatis三大执行器介绍


    Mybatis三大执行器介绍

    • Mybatis相关全览
    • 一、执行器介绍
      • 执行器的选择入口
      • 设置执行器两种方式
        • 全局配置(不建议)
        • 局部设置(建议)
    • 二、三个执行器区别
      • SimpleExecutor
      • ReuseExecutor
      • BatchExecutor
      • 总结
    • 三、效率测试
    • 四、平时开发使用

    本文用的是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配置文件中全局设置

    
        
    
    
    • 1
    • 2
    • 3

    局部设置(建议)

    就是在获取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();
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
  • 相关阅读:
    求极限问题:x趋于0时的等价替换及其适用条件、洛必达法
    js 对页面任一地方进行监听点击事件 (如果点击是超链接以另一窗口打开 并 对超链接赋值内容,300毫秒后还原超链接)
    Elastic 网络爬虫:为你的网站添加搜索功能
    生态环境综合管理信息化平台推动生态环境部门数字化转型
    19_Vue如何监测到对象类型数据发生改变的?
    数据库系列:前缀索引和索引长度的取舍
    Cookie 能跨域吗?如何设置?
    (Servlet【九】)HttpServlet类继承GenericServlet类,HttpServlet类源码分析,模板方法设计模式的认识
    MySQL为什么用b+树
    蓝桥杯-回文日期
  • 原文地址:https://blog.csdn.net/weixin_44102992/article/details/127913263
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号