mybatis的原理

本文详细解析了MyBatis的九大核心组件,包括Configuration、SqlSession、Executor等,以及MyBatis的硬编码方式和源码执行流程,帮助读者深入理解MyBatis的工作原理。

一、mybatis的主要成员

在这里插入图片描述

1. Configuration        MyBatis所有的配置信息都保存在Configuration对象之中,配置文件中的大部分配置都会存储到该类中
2. SqlSession           作为MyBatis工作的主要顶层API,表示和数据库交互时的会话,完成必要数据库增删改查功能
3. Executor             MyBatis执行器,是MyBatis 调度的核心,负责SQL语句的生成和查询缓存的维护
4. StatementHandler 	封装了JDBC Statement操作,负责对JDBC statement 的操作,如设置参数等 
5. ParameterHandler  	负责对用户传递的参数转换成JDBC Statement 所对应的数据类型
6. ResultSetHandler   	负责将JDBC返回的ResultSet结果集对象转换成List类型的集合
7. TypeHandler          负责java数据类型和jdbc数据类型(也可以说是数据表列类型)之间的映射和转换
8. MappedStatement  	MappedStatement维护一条<select|update|delete|insert>节点的封装
9. sqlSource            负责根据用户传递的parameterObject,动态地生成SQL语句,将信息封装到BoundSql对象中,并返回
10.BoundSql             表示动态生成的SQL语句以及相应的参数信息

二、mybatis硬编码方式

1. 配置文件           			String configXml = "mybatis_config.xml";
2. 加载配置获取流     			Reader reader = Resources.getResourceAsReader(configXml);
3. 获取sqlSessionFactory工厂    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
4. 获取sqlSession				SqlSession sqlSession = sqlSessionFactory.openSession();
5. 获取对应的mapper     		    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
6. 执行方法           			UserEntity user = userMapper.getUser(1);

三、mybatis原理

在这里插入图片描述

1. 加载mybatis全局配置文件(数据源、mapper映射文件等),解析配置文件,MyBatis基于XML配置文件生成Configuration,和一个个MappedStatement(包括了参数映射配置、动态SQL语句、结果映射配置),其对应着<select | update | delete | insert>标签项
2. SqlSessionFactoryBuilder通过Configuration对象生成SqlSessionFactory,用来开启SqlSession
3. SqlSession对象完成和数据库的交互
1)用户程序调用mybatis接口层api(即Mapper接口中的方法)
2)SqlSession通过调用api的Statement ID找到对应的MappedStatement对象
3)通过Executor(负责动态SQL的生成和查询缓存的维护)将MappedStatement对象进行解析,sql参数转化、动态sql拼接,生成jdbc Statement对象
4)JDBC执行sql
5)借助MappedStatement中的结果映射关系,将返回结果转化成HashMap、JavaBean等存储结构并返回

四、mybatis源码解读

1. 首先,SqlSessionFactoryBuilder去读取mybatis的配置文件,然后build一个DefaultSqlSessionFactory
	1)主要是读取mybatis-config的配置信息,里面的配置都在这个阶段解析设置
	2)也可以以配置SqlSessionFactoryBean的方式来加载配置文件
2. 当我们获取到SqlSessionFactory之后,就可以通过SqlSessionFactory去获取SqlSession对象 
	1)主要是DefaultSqlSessionFactory.openSessionFromDataSource()方法,会设置一些configuration和事务的配置信息
3. 拿到SqlSession对象之后,还要有映射文件信息啊
	1)可以通过配置MapperScannerConfigurer的Bean加载指定包下的Dao(加了@Repository?)	
4. 在mybatis中,通过MapperProxy动态代理咱们的dao,也就是说,当咱们执行自己写的dao里面的方法的时候,其实是对应的mapperProxy在代理
	1)执行dao的时候,MapperProxy.invoke()方法开始执行
	2)调到MapperMethod根据sql的CRUD类型(select/updata/insert/delete)选择调sqlSession的哪个方法
	3)也可以根据 sqlSession.getMapper(Class<T> type) 来获取mapper(其实生成的就是MapperProxy对象),再调mapper.定义的方法(会走1)2)的步骤)
	4)一个是集成在spring的扫描包中,一个是直接通过编程方式获取,最终都是MapperProxy代理对象去执行,都会走到2)的判断CRUD
5. 执行sqlSession的方法 selectOne/selectList/update ... 
	1)实现类DefaultSqlSession
6. 进入到具体的sqlSession方法,比如selectList方法
	1)方法内,根据id获取到MappedStatement对象(configuration对象里其实维护了一个map -> mappedStatements  全类名.方法名),包括sqlSource、resultMap等信息
	2)然后调Executor对象执行(实现类BaseExecutor)(这里已经传了分页信息rowBounds)
7. BaseExecutor调最后的doQuery()方法 
	1)交给jdbc的底层PreparedStatementHandler去处理
8. PreparedStatementHandler真正执行sql
	1)	PreparedStatement ps = (PreparedStatement) statement 、ps.execute()
9. 最后返回的PreparedStatement ps交给ResultSetHandler去处理
	1)实现类DefaultResultSetHandler去把返回结果解析成List或者map

参考网址

《深入理解mybatis原理》 MyBatis的架构设计以及实例分析*

深入浅出Mybatis系列(十)—SQL执行流程分析(源码篇)

注:文章是经过参考其他的文章然后自己整理出来的,有可能是小部分参考,也有可能是大部分参考,但绝对不是直接转载,觉得侵权了我会删,我只是把这个用于自己的笔记,顺便整理下知识的同时,能帮到一部分人。
ps : 有错误的还望各位大佬指正,小弟不胜感激

<think>好的,我现在需要回答用户关于MyBatis原理及架构图的问题。用户希望了解MyBatis的整体架构、核心模块以及工作流程。首先,我需要回忆MyBatis的基本结构,确保信息的准确性。 根据用户提供的引用内容,MyBatis有解析器模块,负责解析XML配置文件,使用XPath进行高效解析。这一点需要强调。另外,一级缓存的作用也被提到,说明MyBatis在会话级别进行了缓存优化,减少数据库查询次数。 接下来,我应该分模块介绍MyBatis的架构。可能括接口层、核心处理层、基础支撑层等。需要结合用户提到的解析器模块和缓存机制,将这些部分整合到相应的层级中。例如,解析器属于基础支撑层,而一级缓存可能属于核心处理层的会话管理部分。 用户还提到需要架构图,虽然无法直接绘制,但可以通过文字描述各个组件之间的关系。例如,SqlSessionFactoryBuilder读取配置文件,创建SqlSessionFactory,再由其生成SqlSession,执行SQL语句。 工作流程部分,应该从配置文件加载开始,到SQL执行、结果映射结束。每个步骤需要简要说明,如解析配置文件、创建会话、Executor执行查询等。同时,要提到一级缓存在会话中的作用,以及可能存在的二级缓存。 需要确保使用正确的中文术语,避免直译英文词汇。同时,按照用户要求,行内公式用$...$,但这个问题可能不涉及数学公式,所以可能不需要使用。但如果有涉及表达式的地方,比如动态SQL中的条件,可能需要适当应用。 最后,生成相关问题,考虑用户可能的后续疑问,如缓存机制、XML配置解析、插件扩展等。确保问题与MyBatis的核心功能相关,帮助用户深入理解。 检查引用标记是否正确添加,确保引用内容与用户提供的资料对应。例如,解析器模块引用[^2],一级缓存引用[^3],源码调试建议引用[^1]。 可能需要注意避免技术细节过于复杂,保持解释清晰易懂。同时,确保各部分逻辑连贯,结构合理,符合用户要求的层次结构。</think>### MyBatis 原理与架构解析 #### 一、MyBatis 核心架构分层 MyBatis 架构分为三层: 1. **接口层**:提供与数据库交互的 API(如 `SqlSession`),支持直接调用 SQL 或 Mapper 接口。 2. **核心处理层**: - **配置解析**:解析 `mybatis-config.xml` 和 `Mapper.xml` 文件,依赖 **XPath 实现高效解析** 。 - **SQL 执行**:通过 `Executor` 处理 SQL 请求,含**一级缓存**(会话级缓存,减少重复查询)。 - **结果映射**:将 JDBC 返回的 `ResultSet` 转换为 Java 对象。 3. **基础支撑层**: - **连接池**:管理数据库连接。 - **事务管理**:支持本地事务与分布式事务。 - **插件扩展**:通过拦截器机制扩展功能(如分页插件)。 #### 二、MyBatis 工作流程 1. **初始化阶段**: - 加载 `mybatis-config.xml`,解析全局配置(数据源、插件等)。 - 解析 `Mapper.xml`,生成 `MappedStatement` 对象存储 SQL 映射信息。 2. **SQL 执行阶段**: ```java // 示例代码 SqlSession session = sqlSessionFactory.openSession(); User user = session.selectOne("com.example.mapper.UserMapper.selectById", 1); ``` - **会话创建**:通过 `SqlSessionFactory` 创建 `SqlSession`。 - **请求处理**:`Executor` 执行 SQL,优先检查**一级缓存** 。 - **结果返回**:通过 `ResultHandler` 转换结果集。 #### 三、架构图关键组件 ``` [用户代码] → SqlSession → Executor → JDBC → Database ↑ ↑ | |— 一级缓存 |— MappedStatement(SQL/参数映射) |— Configuration(全局配置) ``` - **一级缓存**:默认开启,生命周期与 `SqlSession` 一致,相同 SQL 直接返回缓存结果。 - **插件机制**:可拦截 `Executor` 等方法,实现性能监控或 SQL 改写。 #### 四、调试与源码学习建议 建议通过 IDE(如 IntelliJ IDEA)**Debug MyBatis 源码**,重点关注: 1. `XMLConfigBuilder`:解析全局配置。 2. `XMLMapperBuilder`:解析 Mapper 文件[^2]。 3. `CachingExecutor`:缓存处理逻辑[^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值