Redian新闻
>
七张图解锁Mybatis整体脉络,让你轻松拿捏面试官

七张图解锁Mybatis整体脉络,让你轻松拿捏面试官

公众号新闻

👉 这是一个或许对你有用的社群

🐱 一对一交流/面试小册/简历优化/求职解惑,欢迎加入芋道快速开发平台知识星球。下面是星球提供的部分资料: 

👉这是一个或许对你有用的开源项目

国产 Star 破 10w+ 的开源项目,前端包括管理后台 + 微信小程序,后端支持单体和微服务架构。

功能涵盖 RBAC 权限、SaaS 多租户、数据权限、商城、支付、工作流、大屏报表、微信公众号等等功能:

  • Boot 地址:https://gitee.com/zhijiantianya/ruoyi-vue-pro
  • Cloud 地址:https://gitee.com/zhijiantianya/yudao-cloud
  • 视频教程:https://doc.iocoder.cn

来源:juejin.cn/post/
7283798251403821056


本文笔者计划从全局角度来对Mybatis的整体架构及进行一次回顾和总结,希望能帮助你更加透彻的理解Mybatis。

1 前言

MyBatis是一款ORMObject-Relational Mapping)框架,其主要用于将Java对象与关系数据库之间进行映射,凭借其轻量性、稳定性以及广泛的开源社区其受到了广大开发者的追捧。

MyBatis为我们做了哪些事情呢?其实,总结来看主要有如下几点:

  1. SQL映射配置MyBatis使用XML或注解配置文件来定义SQL查询、插入、更新和删除操作,以及与数据库表之间的映射关系。这使得开发者能够将SQL语句与Java代码分离,提高了代码的可维护性。
  2. 动态SQLMyBatis支持动态SQL,允许根据不同的条件生成不同的SQL语句。这使得构建复杂的查询变得更加灵活和方便。
  3. 参数映射MyBatis能够将Java对象的属性与SQL语句中的参数进行映射,无需手动编写繁琐的参数传递代码。
  4. 结果集映射MyBatis支持将SQL查询结果映射到Java对象,自动将数据库表中的列值赋给Java对象的属性,大大简化了数据的读取和处理。
  5. 事务管理MyBatis可以与Java的事务管理框架(如Spring)无缝集成,确保数据库操作的原子性和一致性。
  6. 连接池集成MyBatis可以与常见的Java连接池库(如Apache DBCP、C3P0、HikariCP)集成,以管理数据库连接的获取和释放。
  7. 二级缓存MyBatis支持二级缓存,可以在多个会话之间共享数据,提高性能。

知晓了MyBatis的功能特性后,接下来让我们一起来看看MyBatis内部是通过哪些组件来支撑起这些功能的。

基于 Spring Boot + MyBatis Plus + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城等功能

  • 项目地址:https://github.com/YunaiV/ruoyi-vue-pro
  • 视频教程:https://doc.iocoder.cn/video/

2 总览MyBatis

对于Mybatis的架构大致可以分为三层:基础支持层核心处理层接口层。

或许,你会觉得上图过于复杂,难以理解。如果此刻你也有这样的疑惑,不要慌。不妨跟着笔者思路来进行梳理。

首先,使用MyBatis概括来看大致包括如下几步:

  1. 定义接口,配置相关的xml文件信息
  2. 加载接口的配置文件,解析相关配置文件
  3. 生成接口代理类,执行相关sql

由于在使用MyBatis过程中会编写相关的配置文件,所以Mybatis内部必然需要相应组件来支撑配置文件的解析,这些也就构成了底层的基础支撑层。既然会解析配置文件,那是不是必然会涉及到资源加载、配置解析等模块?

进一步,当配置文件解析完成后,下一步就是生成代理,然后执行sql,此时所涉及的也就是核心处理层中的sql执行,sql解析等。更进一步,执行sql过程中为了避免Connection频繁创建,是不是需要对连接进行池化操作?所以MyBatis内部会抽象出一个数据源模块来统一管理连接。

除此之外,对于sql执行过程中的事务是不是也需要控制?所以MyBatis还有事务管理模块来对sql执行过程中的事务进行管理。

事实上,你只需要记住Mybatis的使用过程为:定义接口,提供配置文件,而后生成代理,执行Sql 即可 。以此进行发散,自然而然能扩展出上图所示内容,根本没必要死记硬背。

熟悉了MyBatis的整体架构后,我们接下来看Mybatis内部执行sql的大致流程:

接下来,我们将主要围绕这张图中内容进行总结分析。

基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城等功能

  • 项目地址:https://github.com/YunaiV/yudao-cloud
  • 视频教程:https://doc.iocoder.cn/video/

3 配置文件解析

配置文件解析过程大致如下所示:

事实上,MyBatis内部对于配置文件解析的过程可以概括如下:

  1. 加载配置文件 :MyBatis首先加载主配置文件(通常是mybatis-config.xml),并创建一个Configuration对象来表示整个MyBatis配置。
  2. 解析主配置文件 :MyBatis使用XML解析器解析主配置文件,该文件包含了关于数据源、插件、类型别名、缓存等全局配置信息。这些配置会被存储在Configuration对象中。

而参与配置文件解析的都继承与BaseBuilder,其体系结构如下所示:

其中

  1. XMLStatementBuilder :这个类用于解析映射文件中的 <select><insert><update><delete> 等标签,构建与 SQL 语句相关的对象(如 MappedStatement),包括 SQL 语句的解析、参数映射、结果映射等。
  2. XMLMapperBuilderXMLMapperBuilder 用于解析映射文件(通常是 Mapper.xml 文件),负责构建与映射文件相关的对象,包括映射文件的解析、SQL 语句的构建、参数映射、结果映射、缓存配置等。
  3. XMLConfigBuilderXMLConfigBuilder 用于解析主配置文件(通常是 mybatis-config.xml 文件),负责构建与全局配置相关的对象,包括数据源配置、类型别名配置、插件配置、缓存配置等。

总结来看,对于MyBatis的加载过程来说,其在处理配置文件信息时,首先,会传递配置文件所在位置信息,然后再调用框架提供的SqlSessionFactorybuild方法便会根据传入路径信息去加载相关的配置文件,并进行解析。而解析的内容会存放到的configuration之中,进而方便后续组件的使用。

4 代理构建

当配置文件解析,下一步就是通过SqlSessiongetMapper方法来构建一个接口对应的代理类,这一过程大致如下:

这一过程中涉及的组件主要包括MapperProxyFactory、MapperRegistry、MapperProxy,更加详细的分析可参考Mybatis流程分析(六): Mybatis中方法和sql语句的桥梁——MapperProxy, 总之这一过程的本质就是通过Jdk动态代理的方式返回一个实现接口的实例对象

  • 传送门:https://juejin.cn/post/7273434821807947811

5 sql执行

当配置文件解析完成,接口相应的代理类构建完毕后,下一步要做的就是sql的执行,这一过程逻辑大致如下所示:

这一部分的底层逻辑就是原生JDBC操纵数据库的那一套逻辑,即

  1. 创建SQL语句 :即创建StatementPreparedStatementCallableStatement对象,分别用于执行不同类型的SQL语句。
  2. 执行SQL查询 :使用创建的StatementPreparedStatement对象来执行SQL查询。
  3. 处理查询结果 :通过ResultSet对象来处理查询的结果数据。

6 总结

最后,我们再来一下Mybatis内部对于sql执行的大致步骤:

  1. 创建 SqlSessionFactory :使用Mybatis首先需要创建一个 SqlSessionFactory 对象,这通常通过读取MyBatis 的主配置文件(mybatis-config.xml)并使用 SqlSessionFactoryBuilder 来实现。SqlSessionFactory 负责创建数据库连接和 SqlSession 对象。
  2. 创建 SqlSession :通过 SqlSessionFactory 创建一个 SqlSession 对象。SqlSession 代表了与数据库的一次会话,它可以执行 SQL 操作并管理数据库连接。通常,每个线程都会创建自己的 SqlSession
  3. 执行 SQL 语句 :在 SqlSession 中,通过调用方法执行 SQL 语句。MyBatis 支持多种方式来执行 SQL,包括 selectOne()selectList()insert()update()delete() 等方法。
  4. SQL 语句解析MyBatis 会解析 SQL 语句,包括动态 SQL,参数映射和结果映射。这包括了将 Java 对象转化为 SQL 语句中的参数,以及将查询结果映射回Java对象。
  5. 执行 SQLMyBatisSQL 语句发送到数据库,并执行相应的操作,如查询、插入、更新或删除。数据库返回结果或受影响的行数,这取决于SQL语句的类型。
  6. 处理结果MyBatis 最终会将SQL的执行结果映射为 Java 对象,然后返回给调用者。映射过程通常基于映射文件中的配置。结果集的处理包括将数据库查询结果映射为 Java 对象的属性值。

进一步,上述步骤可总结概括总结为如下的流程。

ps:如果觉得文章不错的话,不妨点赞收藏方便日后复习,或者加个关注不错过每一次更新😘


欢迎加入我的知识星球,全面提升技术能力。

👉 加入方式,长按”或“扫描”下方二维码噢

星球的内容包括:项目实战、面试招聘、源码解析、学习路线。

文章有帮助的话,在看,转发吧。

谢谢支持哟 (*^__^*)

微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
研究 I 不想显老?这些原则让你轻松年轻五岁纽约遇上西雅图:Lyft/亚马逊面试官校招面试Tips独家分享会今年秋冬这么穿,时髦高级知识分子风轻松拿捏【娱乐】巴黎音乐之旅:11月末传统音乐会攻略,让你轻松感受音乐魅力!酿丸子|附华夏厨师祖师爷简介|味之精微,口不能言丈夫出轨亲姐!妹子杀到面试现场,直接开揍,吓傻面试官人老了要紧握的七张底牌抢夺人才的七张大饼!我能吃到吗?深度好文|数据分析黑话大公开,轻松拿捏面试官!【图解】提高综合效益和整体运管水平,我市出台加强社会组织培育基地建设的意见中文版Rhino+GH教程终于来了!让你轻松成为建模高手!第一章第三节 人类的思想语言【线下活动】就在本周四! 亚马逊面试官来UIUC, 1v1修改简历/内推/模拟面试......初秋高级穿搭,法式V领山茶花开衫,温柔优雅气质轻松拿捏惊呆!澳洲成留学生心中首选目的地!原因竟是好就业?尤其在澳洲学医,失业率几乎为0!这些途径带你轻松进入医学院!华人必看!面试美国Capital One遭遇中国面试官,这位藤校学长差点翻车…面试攻略 | 面试现场,让面试官把代码写出来?!招生官看了一秒录取:这五个关键点让你轻松写出好文书!第一章第二节 护卫亲子的行为法则已入职!字节算法面试真题附答案,迅速搞定大厂面试官神秘的大杂院(九)拎潲水桶的女孩不会面试提问?在面试中如何向面试官提问不会出错巴黎音乐之旅:十一月末传统音乐会攻略,让你轻松感受音乐魅力![电脑] 8000MHz轻松拿捏,超详细的微星主板降压超频教程数据分析黑话大公开,轻松拿捏面试官!耶鲁、哈佛推荐的金融面试指南PDF,连高盛面试官都在用凹造型少不了的顶流帽子,大头围也超爱!秋冬氛围感轻松拿捏!人生七张保单:是普世真理还是套路大坑?——拒绝韭菜 买对管好 手把手带你练就火眼金睛面试官希望你这样来面试:最佳实践经验【双养日课】致养育者们:捕捉儿童敏感期脉络,让养育事半功倍第一章第一节 自我利益最大化的行为法则真德绒·真保暖 德国吸湿发热黑科技让你轻松面对寒冬 寒风凛冽轻装上阵"妈妈让我来自首",7岁男孩在派出所写下"bǎozhèng书"留学干货 | 文献资料查找指南,让你轻松成为学术达人!直播预告| 松弛感时髦感轻松拿捏!
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。