MyBatis的执行流程分析
核心流程介绍
我们都知道 MyBatis
是对 JDBC 的封装,不管怎样,JDBC 的那一套还是不会变的,只是做了抽象、封装、归类等;所以我们顺着 JDBC 的思路来说下MyBatis
的执行流程,JDBC执行六部走
- 注册驱动
- 获取Connection连接
- 执行预编译
- 执行SQL
- 封装结果集
- 释放资源
然后通过这张图来分析下MyBatis
的是怎样来封装这个过程的:
MyBatis执行八步走
上面中流程就是 MyBatis
内部核心流程,咱么来一步步解释下
- 读取
MyBatis
的核心配置文件。mybatis-config.xml
为MyBatis
的全局配置文件,用于配置数据库连接、属性、类型别名、类型处理器、插件、环境配置、映射器 (mapper.xml)等信息,这个核心配置文件最终会被封装成一个Configuration
对象。 - 加载映射文件。映射文件即SQL映射文件,该文件中配置了操作数据库的SQL语句,映射文件是在
mybatis-config.xml
中加载;可以加载多个映射文件,每个文件对应数据库中的—张表。配置的方式有两种:
<!-- 使用包路径,扫描包下所有的接口,这种方式比较方便 -->
<package name="com.mybatis.demo"/>
<!-- resource∶使用相对路径的资源引用-->
<!-- url∶使用绝对类路径的资源引用-->
<!-- class∶使用映射器接口实现类的完全限定类名-->
<mapper resource="xxx.xml"/>
构造会话工厂获取
SqlSessionFactory
。这个过程其实是用建造者设计模式使用SqlSessionFactoryBuilder
对象构建的,SqlSessionFactory
的的最佳作用域是应用作用域创建会话对象
SqlSession
。由会话工厂创建SqlSession
对象,对象中包含了执行SQL语句的所有方法,每个线程都应该有它自己的SqlSession
实例。SqlSession
的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。Executor
执行器。是MyBatis
的核心,负责 SQL 语句的生成和查询缓存的维护,它将根据SqlSession
传递的参数动态地生成需要执行的SQL语句,同时负责查询缓存的维护SimpleExecutor -SIMPLE
就是普通的执行器。ReuseExecutor
-执行器会重用预处理语句(PreparedStatements
)BatchExecutor
--它是批处理执行器
MappedStatement
对象。MappedStatement
是对解析的SQL的语句封装,一个MappedStatement
代表了一个sql语句标签,如下∶
<select id="selectUserList" resultType="com.mybatis.User">
select * from t_user
</select>
- 输入参数映射。输入参数类型可以是基本数据类型,也可以是 Map 、List 、 POJO 类型复杂数据类型,这个过程类似于 JDBC 的预编译处理参数的过程。
- 封装结果集。可以封装成多种类型可以是基本数据类型,也可以是 Map、 List 、 P0JO 类型复杂数据类型。封装结果集的过程就和 JDBC 封装结果集是一样的。
这样一对比,就可以看出了其实 Mybatis
的执行流程和 JDBC 其实大同小异
如果用代码表示如下∶
// 1.加载配置文件
InputStream inputStream= Resources.getResourceAsStream("mybatis-config.xmL");
// 2.创建SqLSessionFactory对象实际创建的是Default SqLSessionFactory对象
SqlSessionFactory builder=new SqlSessionFactoryBuilder().build(inputStream);
//3.创建SqLSession对象实际创建的是DefaultSqLSess ion对象
SqLSession sqLSession= builder.openSession();
// 4.创建代理对象
UserMapper mapper=sqLSession.getMapper(UserMapper. class);
// 5.执行查询语句
List<User> users = mapper.selectUserList();
小结
这节主要通过对 JDBC 执行步骤的分析来对比分析 MyBatis
的执行的流程,总体上来看它们的执行步骤基本是一样的,所以大家是不是觉得 MyBatis
这个框架其实也挺简单的,总结下就是
- 加载解析配置文件
- 处理参数
- 执行查询
- 封装结果集
MyBatis的执行流程分析的更多相关文章
- 深入浅出Mybatis系列(十)---SQL执行流程分析(源码篇)
最近太忙了,一直没时间继续更新博客,今天忙里偷闲继续我的Mybatis学习之旅.在前九篇中,介绍了mybatis的配置以及使用, 那么本篇将走进mybatis的源码,分析mybatis 的执行流程, ...
- 深入浅出Mybatis系列十-SQL执行流程分析(源码篇)
注:本文转载自南轲梦 注:博主 Chloneda:个人博客 | 博客园 | Github | Gitee | 知乎 最近太忙了,一直没时间继续更新博客,今天忙里偷闲继续我的Mybatis学习之旅.在前 ...
- Mybatis 系列10-结合源码解析mybatis 的执行流程
[Mybatis 系列10-结合源码解析mybatis 执行流程] [Mybatis 系列9-强大的动态sql 语句] [Mybatis 系列8-结合源码解析select.resultMap的用法] ...
- MyBatis详细执行流程
mybatis详细执行流程 一.通过Resource去加载全局配置文件 import org.apache.ibatis.io.Resources; import org.apache.ibatis. ...
- 报时机器人的rasa shell执行流程分析
本文以报时机器人为载体,介绍了报时机器人的对话能力范围.配置文件功能和训练和运行命令,重点介绍了rasa shell命令启动后的程序执行过程. 一.报时机器人项目结构 1.对话能力范围 (1)能够 ...
- ThinkPHP 框架执行流程分析
总体来说,应用的流程涉及到几个文件:Index.phpThinkPHP.phpThink.class.phpApp.class.phpDispatcher.class.phpThinkPHP/Mode ...
- Spring 文件上传MultipartFile 执行流程分析
在了解Spring 文件上传执行流程之前,我们必须知道两点: 1.Spring 文件上传是基于common-fileUpload 组件的,所以,文件上传必须引入此包 2.Spring 文件上传需要在X ...
- [转]两表join的multi update语句在MySQL中的执行流程分析
出自:http://hedengcheng.com/?p=209 两表join的multi update语句,执行结果与预计不一致的分析过程 — multi update结论在实际应用中,不要轻易使用 ...
- Hive SQL执行流程分析
转自 http://www.tuicool.com/articles/qyUzQj 最近在研究Impala,还是先回顾下Hive的SQL执行流程吧. Hive有三种用户接口: cli (Command ...
- spark-sql执行流程分析
spark-sql 架构 图1 图1是sparksql的执行架构,主要包括逻辑计划和物理计划几个阶段,下面对流程详细分析. sql执行流程 总体流程 parser:基于antlr框架对 sql解析,生 ...
随机推荐
- Web攻防--JS算法逆向--断点调试--反调试&&代码混淆绕过
Web攻防--JS算法逆向--断点调试--反调试&&代码混淆绕过 JS算法逆向 在进行渗透测试过程中,在一些功能点进行参数注入或者枚举爆破等过程中,会出现参数进行加密的情况,但是我们输 ...
- fastapi启动后访问docs不显示页面的问题
笔者之前正常使用fastapi的docs接口进行各种接口调试,使用很正常,之前安装也都是正常安装流程,没有做任何修改,可以突然有一天不知道为啥,docs接口打开是空白的,接口也没有报错,就是空白,摸索 ...
- ORM查询一个表中有两个字段相同时,只获取某个值最大的一条
Table表如下: 获取表中name和hex值相同时age最大的那一条 ORM写法,两次查询 ids = table.values('name', 'age').annotate(id=Max('id ...
- 转载|QA|Pycharm一行代码太长如何换行?|Pycharm|工具相关
- DBA容灾与备份恢复:闪回应用及实践(一)
闪回应用及实践 针对主机故障.网络故障.系统软件故障.存储介质故障.人为操作失误等各类故障,可以通过RAC.RMAN.Data Guard等成熟的解决方案来处理,不过对于人为操作失误防范的首推技术还是 ...
- 轻量通讯协议 --- MQTT
介绍 一.MQTT简介 MQTT(Message Queuing Telemetry Transport) 是一种轻量级的消息传输协议,通常用于在物联网(IoT)和传感器网络中进行通信.它设计用于在低 ...
- Python操作Word水印:添加文字或图片水印
在Word文档中,可以添加半透明的图形或文字作为水印,以保护文档的原创性,防止未经授权的复制或使用.除了提供安全功能外,水印还可以展示文档创作者的信息.附加的文档信息,或者仅用于文档的装饰.本文将介绍 ...
- 使用fontforge进行字体拆分
fontforge官方网站 游戏开发为了节省内存和资源下载量,需要把字体不用的字删掉,或者拆成多个字体逐级加载,批量操作用UI就比较难搞了,用fontforge搞起来比较顺手 安装fontforge后 ...
- Unity - UIWidgets 6. 显示列表
为了更贴近游戏实际ui的效果和使用环境, 从而讨论上一节遗留的问题, 列表显示是必不可少的 参考 修改之前的HomeRoute, private Widget CreateListTest() { L ...
- TOPSIS模型
TOPSIS模型主要是用于评估类模型 一些基本概念: 因为TOPSIS模型是用于评价类的模型,所以会有一些指标的概念,所有指标并非越大越好,例如我们在评价一人的时候会有成绩.和他人发生争吵的次数这两个 ...